스프링프레임워크 Java config로 MyBatis 사용하기
스프링프레임워크에 MyBatis + MySQL(MairaDB) 환경을 Java Config로 구성해 봅니다. 앞의 글 "Maven 웹 프로젝트에 스프링프레임워크 적용하기"에 추가하여 구성합니다.
"스프링 프레임웍에서 MyBatis, Oracle 사용하기"에서의 xml 설정을 Java Config로 옮겨본 것입니다. 데이터베이스는 Oracle 대신에 MariaDB를 사용했습니다. 전체 소스는 글 하단에 첨부 했습니다.
1. pom.xml 파일에 필요한 의존성을 추가합니다.
<!-- 스프링에서 JDBC 를 사용하기 위한 라이브러리 입니다. -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${org.springframework-version}</version>
</dependency>
<!-- JSP페이지에서 사용한 JSTL을 위한 라이브러리입니다. -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<!-- 데이터베이스 커넥션 풀을 위한 라이브러리입니다. -->
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-dbcp2</artifactId>
<version>2.6.0</version>
</dependency>
<!-- MySQL JDBC 드라이브 입니다. -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.15</version>
</dependency>
<!-- MyBatis 라이브러리 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.0</version>
</dependency>
<!-- 마이바티스와 스프링 연동을 위한 라이브러리 -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.0</version>
</dependency>
2. 데이터베이스 연결과 트랜잭션 설정을 합니다.
@EnableTransactionManagement 아노테이션은 DataSourceTransactionManager 빈을 찾아 Transaction Manager로 사용합니다.
package com.tistory.offbyone.init;
import javax.sql.DataSource;
import org.apache.commons.dbcp2.BasicDataSource;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import org.springframework.transaction.annotation.EnableTransactionManagement;
/**
* 데이터베이스 설정
*/
@Configuration
// 아노 테이션 기반 트랜잭션 관리를 사용 합니다.
// <tx:annotation-driven>
@EnableTransactionManagement
public class ContextDataSource {
/**
* 데이터소스 등록
* @return
*/
@Bean(destroyMethod="close")
public DataSource dataSource() {
BasicDataSource dataSource = new BasicDataSource();
dataSource.setDriverClassName("com.mysql.cj.jdbc.Driver");
dataSource.setUrl("jdbc:mysql://127.0.0.1:3306/testdb?serverTimezone=UTC");
dataSource.setUsername("testdbadm");
dataSource.setPassword("testdbadm");
dataSource.setDefaultAutoCommit(false);
return dataSource;
}
/**
* 트랜잭션 매니저 등록
* @return
*/
@Bean
public DataSourceTransactionManager transactionManager() {
return new DataSourceTransactionManager(dataSource());
}
}
3. MyBatis 설정을 합니다.
@MapperScan 아노테이션은 지정된 베이스 패키지에서 DAO(Mapper) 를 검색하여 등록합니다
package com.tistory.offbyone.init;
import java.io.IOException;
import javax.sql.DataSource;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.SqlSessionTemplate;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
@Configuration
@MapperScan(basePackages = {"com.tistory.offbyone.service.impl"})
public class ContextSqlMapper {
@Autowired
ApplicationContext applicationContext;
@Bean
public SqlSessionFactoryBean sqlSessionFactory(DataSource dataSource) throws IOException {
SqlSessionFactoryBean factoryBean = new SqlSessionFactoryBean();
factoryBean.setDataSource(dataSource);
factoryBean.setConfigLocation(applicationContext.getResource("classpath:/mybatis/mybatis-config.xml"));
factoryBean.setMapperLocations(applicationContext.getResources("classpath:/mybatis/mappers/*.xml"));
return factoryBean;
}
@Bean
public SqlSessionTemplate sqlSession(SqlSessionFactory sqlSessionFactory) {
return new SqlSessionTemplate(sqlSessionFactory);
}
}
4. 루트 컨텍스트 설정에서 다른 설정들을 import 합니다.
package com.tistory.offbyone.init;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.context.annotation.Import;
/**
* 루트 컨텍스트 설정파일
*/
@Configuration
// 설정 클래스들을 import 합니다.
@Import({
ContextDataSource.class
, ContextSqlMapper.class
})
// 서비스 빈 객체들을 등록합니다.
@ComponentScan(basePackages = {"com.tistory.offbyone.service.impl"})
public class RootContextConfiguration {
}
5. MyBatis 설정과 샘플 Mapper 파일 입니다.
mybatis-config.xml, TB_Board_SQL.xml 파일 입니다. 이 파일들도 Java 설정으로 만들 수 있지만 이 부분은 XML 파일로 두겠습니다.
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration PUBLIC "-//mybatis.org//DTD Config 3.0//EN" "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
<!-- 여러가지 기본 옵션을 지정합니다. -->
<settings>
<!-- 필드 속성이 READ_COUNT 처럼 언더 스코어가 있을 때 VO 의 readCount 처럼 카멜 케이스로 변환 되게 합니다. -->
<setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>
<typeAliases>
<typeAlias alias="boardVO" type="com.tistory.offbyone.service.BoardVO"/>
</typeAliases>
</configuration>
<?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">
<!-- 맵핑될 DAO 인터페이스의 Full name 을 줍니다. -->
<mapper namespace="com.tistory.offbyone.service.impl.BoardDAO">
<!-- id 속성은 DAO 의 메소드와 같아야 한다. 여기의 boardVO 는 mybatis-confg.xml 에 Alias 되어 있습니다. -->
<select id="selectBoardList" resultType="boardVO">
SELECT NUM
, NAME
, TITLE
, CONTENT
, READ_COUNT
, WRITE_DATE
FROM TB_BOARD
ORDER BY NUM DESC
</select>
<insert id="insertBoard">
INSERT INTO TB_BOARD VALUES (#{num}, '홍길동','게시물 작성', '글 내용', 0, NOW())
</insert>
</mapper>
6. 실행 결과 입니다.
※ 예제소스