[Spring-Framework] Spring Framework 5.4, MyBatis 3.5 연동 방법 - 실험 결과
아마 이런 실험을 시도한 인터넷 글은 최초가 되지 않을까 싶다.
현재에 떠돌아 다니는 정보들을 충분한 시간을 가지고 실험한 결과이다.
필자가 구독자들에게 한 가지 약속한다면, 검증을 확실히 완료하고 작성한 글이다.
이 글을 어떻게 전달해야 할지 고민을 충분히 하고 작성하게 되었다.
@Autowired 방식과 @Beans 방식을 사용하는 유저가 있다면, 사용하지 않아야 한다.
1. 결과
엄격한 태스트를 거쳐서 완료한 결과이다. 개발 환경을 구축하는데 있어서 삽질을 하지 않았으면 하는 바람이다.
그림 1. 실험 결과
[첨부(Attachments)]
2. 5가지 방법 - 정리
정리가 완료되는데로 공개하도록 하겠다.
1. [Spring-F.] 25. MyBatis 3.5, Spring Framework 5.4, Oracle 19g - 방법1(web.xml-Beans) // 결과: 미지원, 2020-10-02
- https://yyman.tistory.com/1438
2. [Spring-F.] 26. MyBatis 3.5, Spring Framework 5.4, Oracle 19g - 방법2(SqlMap-XML-XML 맵핑) // 결과: 지원, 2020-10-02
- https://yyman.tistory.com/1439
3. [Spring-F.] 27. MyBatis 3.5, Spring Framework 5.4, Oracle 19g - 방법3(SqlMap-XML-Class) // 결과: 지원, 2020-10-02
- https://yyman.tistory.com/1440
4. [Spring-F.] 28. MyBatis 3.5, Spring Framework 5.4, Oracle 19g - 방법4(SqlMap Spring전용) // 결과: 지원, 2020-10-02
- https://yyman.tistory.com/1441
5. [Spring-F.] 29. MyBatis 3.5, Spring Framework 5.4, Oracle 19g - 방법5(SqlMap Spring전용) // 결과: 지원, 2020-10-02
- https://yyman.tistory.com/1442
= (기타: 표준 지원에 대한 4, 5번 소스코드도 주석으로 포함 처리함.)
3. 실험 조건
실험 조건은 다음과 같다.
* IDE: Spring Tool-Suites 4-4.7.2 (Releases)
* Library:
- Spring-Framework 5.2.9.RELEASE (2020-09-15)
- javax.servlet-api 4.0.1 (2018-04-20)
- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api/4.0.1
- mybatis-spring (2020-06-05) // Spring Framework만 사용가능함.
- https://mvnrepository.com/artifact/org.mybatis/mybatis-spring/2.0.5
- mybatis 3.5.5 (2020-06-04)
- https://mvnrepository.com/artifact/org.mybatis/mybatis/3.5.5
- Spring JDBC
- https://mvnrepository.com/artifact/org.springframework/spring-jdbc/5.2.9.RELEASE
- ojdbc8 (ojdbc8)
- mariadb-java-client 2.7.0 (2020-09-24)
- https://mvnrepository.com/artifact/org.mariadb.jdbc/mariadb-java-client/2.7.0
- mysql-connector-java 8.0.21 (2020-07-12)
* DB:
- Oracle Databases 19g
4. 실험 결과 - 동작 영상
입증하기 위해서 영상을 준비하였다.
영상 1. Spring Framework 5.4, Oracle 19g, Mybatis 3.5 연동하기
영상 2. Spring Framework 5.4, Oracle 19g, Mybatis 3.5 연동하기(실험 1 - 영상 [예])
이런 형태로 프로젝트를 구성한 것이다.
5. 공통 - 프로젝트 생성 방법
5가지 방법에 관한 프로젝트 생성에 관한 것이다.
1~5번의 셋팅은 Build Path, Project Factes, POM.xml은 동일하다.
그림 1. 프로젝트 생성하기(1)
File->New->Spring Legacy Project를 클릭한다.
그림 2. 프로젝트 생성하기(2)
Spring MVC Project를 선택한다.
Next를 클릭한다.
그림 3. 프로젝트 생성하기(3)
top-level package 경로를 입력한 후 Finish를 누른다.
5-1. Build-Path, Project Factes 설정하기
자바 버전을 변경해줄 것이다.
초기 Spring Legacy Project로 Spring MVC Project를 생성하면, 1.6 버전으로 셋팅되어 생성될 것이다.
이러한 것을 변경해줄 것이다.
그림 4. 프로젝트 속성 들어가기
프로젝트를 선택한 후 마우스 오른쪽 버튼을 클릭한다.
Properties를 클릭한다.
그림 5. Build-path 버전 바꾸기
Java-Build Path를 클릭한다.
JRE System Library을 선택한다.
Edit 클릭하고 변경하면 된다.
(JRE -> JavaSE 14로 변경할 것)
Apply를 누른다.
그림 6. Project - Factes 설정하기
Project Factes를 클릭한다.
Java 버전을 14로 변경해준다.
Apply를 누른다.
5-2. Pom.xml 설정하기
pom.xml 설정에 관한 것이다.
그림 7. pom.xml 설정하기(1)
<org.springframework-version>을 5.2.9.RELEASE로 변경하였다.
그림 8. pom.xml 설정하기(2)
javax.servlet-api 버전을 4.0.1로 변경하였다.
그림 9. pom.xml 설정하기(3)
mybatis-spring, mybatis를 추가하였다.
그림 10. pom.xml - 오라클이 설치된 경우에만 따라하기(1)
pom.xml을 마우스 오른쪽 버튼으로 클릭한다.
Maven->Add Dependency를 클릭한다.
그림 11. pom.xml - 오라클이 설치된 경우에만 따라하기(2)
oracle이라고 검색한다.
com.oracle.database.jdbc | ojdbc8을 선택한다.
OK를 누른다.
그림 12. pom.xml - mariadb, mysql-connector 추가하기
추가로 몇 개의 DB 드라이버(MariaDB, MySQL-Connector)를 부착시켰다.
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.example</groupId>
<artifactId>spbatis</artifactId>
<name>Spring-MVC-mybatis</name>
<packaging>war</packaging>
<version>1.0.0-BUILD-SNAPSHOT</version>
<properties>
<java-version>1.6</java-version>
<org.springframework-version>5.2.9.RELEASE</org.springframework-version>
<org.aspectj-version>1.6.10</org.aspectj-version>
<org.slf4j-version>1.6.6</org.slf4j-version>
</properties>
<dependencies>
<!-- Spring -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${org.springframework-version}</version>
<exclusions>
<!-- Exclude Commons Logging in favor of SLF4j -->
<exclusion>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${org.springframework-version}</version>
</dependency>
<!-- AspectJ -->
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>${org.aspectj-version}</version>
</dependency>
<!-- Logging -->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
<version>${org.slf4j-version}</version>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>jcl-over-slf4j</artifactId>
<version>${org.slf4j-version}</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>${org.slf4j-version}</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.15</version>
<exclusions>
<exclusion>
<groupId>javax.mail</groupId>
<artifactId>mail</artifactId>
</exclusion>
<exclusion>
<groupId>javax.jms</groupId>
<artifactId>jms</artifactId>
</exclusion>
<exclusion>
<groupId>com.sun.jdmk</groupId>
<artifactId>jmxtools</artifactId>
</exclusion>
<exclusion>
<groupId>com.sun.jmx</groupId>
<artifactId>jmxri</artifactId>
</exclusion>
</exclusions>
<scope>runtime</scope>
</dependency>
<!-- @Inject -->
<dependency>
<groupId>javax.inject</groupId>
<artifactId>javax.inject</artifactId>
<version>1</version>
</dependency>
<!-- https://mvnrepository.com/artifact/javax.servlet/javax.servlet-api -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<!-- Test -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.7</version>
<scope>test</scope>
</dependency>
<!-- https://mvnrepository.com/artifact/org.mybatis/mybatis-spring -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.5</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.mybatis/mybatis -->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.5</version>
</dependency>
<!-- 스프링에서 JDBC 를 사용하기 위한 라이브러리 입니다. -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>${org.springframework-version}</version>
</dependency>
<dependency>
<groupId>com.oracle.database.jdbc</groupId>
<artifactId>ojdbc8</artifactId>
<version>19.7.0.0</version>
</dependency>
<!-- https://mvnrepository.com/artifact/org.mariadb.jdbc/mariadb-java-client -->
<dependency>
<groupId>org.mariadb.jdbc</groupId>
<artifactId>mariadb-java-client</artifactId>
<version>2.7.0</version>
</dependency>
<!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>8.0.21</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<artifactId>maven-eclipse-plugin</artifactId>
<version>2.9</version>
<configuration>
<additionalProjectnatures>
<projectnature>org.springframework.ide.eclipse.core.springnature</projectnature>
</additionalProjectnatures>
<additionalBuildcommands>
<buildcommand>org.springframework.ide.eclipse.core.springbuilder</buildcommand>
</additionalBuildcommands>
<downloadSources>true</downloadSources>
<downloadJavadocs>true</downloadJavadocs>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.5.1</version>
<configuration>
<source>1.6</source>
<target>1.6</target>
<compilerArgument>-Xlint:all</compilerArgument>
<showWarnings>true</showWarnings>
<showDeprecation>true</showDeprecation>
</configuration>
</plugin>
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>exec-maven-plugin</artifactId>
<version>1.2.1</version>
<configuration>
<mainClass>org.test.int1.Main</mainClass>
</configuration>
</plugin>
</plugins>
</build>
</project>
파일명: pom.xml
[첨부(Attachments)]
6. DB - Table 설계
Spring Security에서 사용자 계정의 테이블 설계를 사용하였다.
그림 13. 테이블 모습
CREATE TABLE comp_users (
username VARCHAR(50) NOT NULL,
password VARCHAR(300) NOT NULL,
enabled INT NOT NULL,
PRIMARY KEY (username)
);
-- 계정
INSERT INTO comp_users (username, password, enabled) VALUES ('user', '$2a$10$x04djNV2e9rpcPPRyXoLk.rMm6iZe2/vYdzpqHQcLeNSYdt7kc30O', 1);
INSERT INTO comp_users (username, password, enabled) VALUES ('admin', '$2a$10$QUddY3O/6ZgkYCR6MFlv9.nqA501Fm0cc/ZxQHX5pwb1o0CYCTiIS', 1);
파일명: Comp_users.sql
[첨부(Attachments)]
6-1. Model - CompUsers.java
공통으로 1~5 프로젝트에서 사용되는 부분이다.
package com.example.spbatis.model;
public class CompUsers {
private String username;
private String password;
private int enabled;
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public int getEnabled() {
return enabled;
}
public void setEnabled(int enabled) {
this.enabled = enabled;
}
}
파일명: CompUsers.java
[첨부(Attachments)]
* 맺음글(Conclusion)
1~5개의 글을 추가로 살펴보면 되겠다.