Java

Spring, PostgreSQL 연동 with MyBatis

OSC131 2018. 6. 3. 19:52
728x90
반응형

Spring, PostgreSQL 연동 


작성일시 : 2018년 06월 03일

목표 : Spring과 PostgreSQL을 연동하여 DB의 데이터를 서버사이드로 로드

환경 : Spring 3.1.1, PostgreSQL 9.6.14, MyBatis 3.4.1



1. DB 설정


DB에서 로드할 임시 데이터 생성



1.1 테스트 테이블 생성


 CREATE TABLE account (

account_idx INTEGER PRIMARY KEY,

id character(8)

)





1.2 테스트 데이터 생성





2. Spring 설정


수정, 추가할 파일



2.1 pom.xml


필요 라이브러리 추가

... 

<dependencies>

    ...

 

    <!-- PostgreSQL 9.4 -->

    <dependency>

        <groupId>org.postgresql</groupId>

        <artifactId>postgresql</artifactId>

        <version>9.4.1209.jre6</version>

    </dependency>

    <!-- MyBatis 3.4 -->

    <dependency>

        <groupId>org.mybatis</groupId>

        <artifactId>mybatis</artifactId>

        <version>3.4.1</version>

    </dependency>

    <!-- MyBatis-Spring 1.3-->

    <dependency>

        <groupId>org.mybatis</groupId>

        <artifactId>mybatis-spring</artifactId>

        <version>1.3.0</version>

    </dependency>

    <!-- Spring-JDBC -->

    <dependency>

        <groupId>org.springframework</groupId>

        <artifactId>spring-jdbc</artifactId>

        <version>${org.springframework-version}</version>

    </dependency>

     

    ...

</dependencies>

...



2.2 jdbc.properties


%Project_Home%\src\main\resources 위치에 jdbc.properties 생성 후 DB 정보 입력(URL, ID, Password는 환경에 맞게 수정 필요)

jdbc.driverClassName=org.postgresql.Driver

# 고정


jdbc.url=jdbc:postgresql://localhost:5432/postgres

# domain 및 db명 환경에 맞게 수정 필요, 

# 'postgres'는 postgreSQL 기본 DB로 디폴트로 존재

# PostgreSQL은 디폴트로 5432 Port 사용


jdbc.username=postgres

jdbc.password=123qwe

# ID, PW



2.3 root-context.xml


%Project_Home%\src\main\webapp\WEB-INF\spring\root-context.xml에 아래와 같이 DB 연동 정보 및 SQL 설정 추가


<?xml version="1.0" encoding="UTF-8"?>

<beans xmlns="http://www.springframework.org/schema/beans"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd">

<!-- Root Context: defines shared resources visible to all other web components -->

<!-- properties -->

    <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">

        <property name="locations" value="classpath:/jdbc.properties" />

        <property name="fileEncoding" value="UTF-8" />

    </bean>

    

    <!-- JDBC-PostgreSQL -->

    <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">

        <property name="driverClassName" value="${jdbc.driverClassName}" />

        <property name="url" value="${jdbc.url}" />

        <property name="username" value="${jdbc.username}" />

        <property name="password" value="${jdbc.password}" />

    </bean>

    

    <bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean"> 

    <property name="mapperLocations" value="classpath*:sql/**/*.xml"/>  

    <property name="dataSource" ref="dataSource" /> 

    </bean> 

    

    <bean id="sqlSessionTemplate" class="org.mybatis.spring.SqlSessionTemplate"> 

    <constructor-arg index="0" ref="sqlSessionFactory" /> 

    </bean>


</beans>



2.4 sql.xml


%Project_Home%\src\main\resources밑에 sql 패키지 생성 후 sql.xml 생성

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">


<mapper namespace="sql">

<select id="sel" resultType="com.company.test.HomeDto">     <!-- resultType 본인 환경에 맞게 수정 필요 -->

SELECT * FROM account

</select>

</mapper> 



기본 제공 HomeController 수정 및 같은 위치에 아래 파일 생성


2.5 HomeController.java


package com.company.test;

import java.util.List;

import org.slf4j.Logger;

import org.slf4j.LoggerFactory;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Controller;

import org.springframework.ui.Model;

import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RequestMethod;

/**

 * Handles requests for the application home page.

 */

@Controller

public class HomeController {

@Autowired

HomeDao homeDao;

private static final Logger logger = LoggerFactory.getLogger(HomeController.class);

@RequestMapping(value = "/", method = RequestMethod.GET)

public String home(Model model) {


List<HomeDto> list = homeDao.sel();

for(int i=0; i<list.size(); i++){

logger.info(list.get(i).getAccount_idx());

logger.info(list.get(i).getId());

model.addAttribute("ID", list.get(0).getId() );

}

return "home";

}

}




2.6 HomeDao.java


package com.company.test;



import java.util.List;

import org.mybatis.spring.SqlSessionTemplate;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Repository;


@Repository

public class HomeDao {

@Autowired

private SqlSessionTemplate sqlSession;

public List<HomeDto> sel(){

return sqlSession.selectList("sql.sel");

}

}



2.7 HomeDto.java


package com.company.test;



public class HomeDto {

private String account_idx;

private String id;

public String getAccount_idx(){

return account_idx;

}

public void setAccount_idx(String account_idx){

this.account_idx=account_idx;

}

public String getId(){

return id;

}

public void setId(String id){

this.id=id;

}

}



2.8 home.jsp


%Project_Home%\src\main\webapp\WEB-INF\views\home.jsp 수정

<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>

<%@ page session="false" %>

<html>

<head>

<title>Home</title>

</head>

<body>

<h1>

Hello world!  

</h1>


<P>  ID is ${ID}. </P>

</body>

</html>

 



3. 확인


3.1 브라우저 접근




3.2 콘솔 로그




DB에 있는 account_idx = 1, id=test의 데이터를 서버사이드로 로드


---


그대로 복붙 시 공백 주의


728x90
반응형