web
Spring Boot - MyBatis
허원철
2017. 4. 13. 19:57
이번 글은 Spring Boot에서 MyBatis를 사용한 글 입니다.
Spring Boot에서는 JPA와는 달리 번거롭게 Bean을 설정하는 작업이 필요하는 등 MyBatis를 제대로 지원해주지 않았는데, 1.5.2(?) 버전에서 프로퍼티가 추가 되었습니다. 그래서 제가 스프링에서 주로 써왔던 MyBatis를 다시 한번 써보고자 작성하게 되었습니다.
1. Gradle
1 2 3 | dependencies { compile("org.mybatis.spring.boot:mybatis-spring-boot-starter") } | cs |
2. 요구사항
- MyBatis-Spring-Boot-Starter는 Java 6 이상 및 MyBatis-Spring 및 Spring Boot 버전이 필요합니다.
MyBatis-Spring-Boot-Starter |
MyBatis-Spring | Spring Boot |
1.3.x (1.3.0) |
1.3 or higher |
1.5 or higher |
1.2.x (1.2.1) |
1.3 or higher |
1.4 or higher |
1.1.x (1.1.1) |
1.3 or higher |
1.3 or higher |
1.0.x (1.0.2) |
1.2 or higher |
1.3 or higher |
3. Domain
- Lombok를 이용하여 간단하게 Domain을 만들어 줍니다.
1 2 3 4 5 6 7 8 | @Data @NoArgsConstructor @AllArgsConstructor public class User implements Serializable { private Long idx; private String name; private String local ; } | cs |
4. SQL
- 해당 예제는 memory를 이용한 h2를 사용했기 때문에 table을 사전에 만들어주는 작업을 했습니다.
- resources 밑에 schema.sql를 만들어 User Table을 만들어줍니다.
1 2 3 4 5 | CREATE TABLE USER ( IDX NUMBER PRIMARY KEY NOT NULL, NAME VARCHAR(20) NOT NULL, LOCAL VARCHAR(20) NOT NULL ); | cs |
5-1. Mapper Annotation
- interface 선언에 @Mapper를 달아주고 해당 @Insert, @Select, @Delete, @Update를 만들어 줍니다.
- argument에 Query에 넣을 값을 지정 할 수 있습니다.
1 2 3 4 5 6 7 8 9 10 11 | @Insert("INSERT INTO USER VALUES (#{idx}, #{name}, #{local})") void insert(@Param("idx") Long idx, @Param("name") String name, @Param("local") String local); @Select("SELECT * FROM USER WHERE IDX = #{idx}") List<User> findByIdx(@Param("idx") Long idx); @Delete("DELETE FROM USER WHERE IDX = #{idx}") void deleteByIdx(@Param("idx") Long idx); @Update("UPDATE USER SET NAME = #{name} WHERE IDX = #{idx}") void setFixedNameByIdx(@Param("name") String name, @Param("idx") Long idx); | cs |
5-2. XML
① properties에서 path를 잡아줍니다.
1 | mybatis.config-location=classpath:mybatis-config.xml | cs |
② 설정 xml 에서 domain에 해당하는 패키지 path와 mapper로 사용되는 xml를 지정해줍니다.
1 2 3 4 5 6 7 8 9 10 11 12 | <?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> <typeAliases> <package name="com.tistory.heowc.domain"/> </typeAliases> <mappers> <mapper resource="mapper/UserMapper.xml"/> </mappers> </configuration> | cs |
③ <insert>, <select>, <delete>, <update> 안에 쿼리를 작성해줍니다.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 | <?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="UserMapper"> <insert id="insert"> INSERT INTO USER VALUES (#{idx}, #{name}, #{local}) </insert> <select id="findByIdx" resultType="User"> SELECT * FROM USER WHERE IDX = #{idx} </select> <delete id="deleteByIdx"> DELETE FROM USER WHERE IDX = #{idx} </delete> <update id="setFixedNameByIdx"> UPDATE USER SET NAME = #{name} WHERE IDX = #{idx} </update> </mapper> | cs |
참고
- 테스트 코드는 Github에 있으니 참고하시기 바랍니다.