SpringFrameworkでMyBatisを使ってみる⑤(Javaアプリケーション)
今回はDaoのImplがないパターンをやってみます。久々なのでPOMのバージョンアップしたり全ソースを載せます。データベースはPostgreSQLを使用します。テーブル作成の作成までは事前に行っておいて下さい。
PostgreSQLはこちらを参照下さい。
単純なSELECT(XMLで設定)
以下のサンプルでは、UserMapperインターフェースを用意するだけで、その実装クラスがなしで使用できます。XMLでMapperFactoryBeanを指定しており、これがsqlSessionFactoryを関連付けられたUserMapperのオブジェクトを作ってくれます。
pom.xml
<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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>springTest</groupId>
<artifactId>springTest</artifactId>
<version>0.0.1-SNAPSHOT</version>
<build>
<sourceDirectory>src</sourceDirectory>
<plugins>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>3.8.0</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
</plugins>
</build>
<dependencies>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>5.1.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.1.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.1.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.postgresql</groupId>
<artifactId>postgresql</artifactId>
<version>42.2.5</version>
</dependency>
<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>
<dependency>
<groupId>ch.qos.logback</groupId>
<artifactId>logback-classic</artifactId>
<version>1.2.3</version>
</dependency>
</dependencies>
</project>
logbackはなくてもmybatisは動作しますが、logbackがあるとSQLのログを出してくれるので、デバッグしやすいです。
SpringTest.xml
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.2.xsd">
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName"
value="org.postgresql.Driver" />
<property name="url"
value="jdbc:postgresql://localhost:5432/postgres" />
<property name="username" value="postgres" />
<property name="password" value="ps" />
</bean>
<bean id="sqlSessionFactory"
class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mapperLocations"
value="C:\\eclipseee\\workspace\\springTest\\resource\\sql.xml" />
</bean>
<bean id="mapper" class="org.mybatis.spring.mapper.MapperFactoryBean">
<property name="mapperInterface" value="spring.test.UserMapper" />
<property name="sqlSessionFactory" ref="sqlSessionFactory" />
</bean>
<bean id="helloWorld" class="spring.test.SpringBean">
<constructor-arg ref="mapper" />
</bean>
</beans>
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="spring.test.UserMapper">
<select id="getUserList" resultType="spring.test.User">
select id,name from m_user
</select>
</mapper>
namespaceには実装クラスを作成したいインターフェースクラスのパッケージ名を含めたクラス名を指定します。
User.java
package spring.test;
public class User {
String id;
String name;
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
UserMapper.java
package spring.test;
import java.util.List;
public interface UserMapper {
public List<User> getUserList();
}
SpringBean.java
package spring.test;
import java.util.List;
public class SpringBean {
private final UserMapper userMapper;
public SpringBean(UserMapper mp) {
this.userMapper = mp;
}
public void show() {
List<User> list = userMapper.getUserList();
for (User user : list) {
System.out.println(user.getId() + "-" + user.getName());
}
}
}
HelloWorldTest.java
package spring.test;
import org.springframework.context.support.FileSystemXmlApplicationContext;
public class HelloWorldTest {
public static void main(String[] args) {
FileSystemXmlApplicationContext context = new FileSystemXmlApplicationContext(
"C:\\eclipseee\\workspace\\springTest\\resource\\SpringTest.xml");
// FileSystemXmlApplicationContext context = new FileSystemXmlApplicationContext("classpath:SpringTest.xml");
SpringBean bean = (SpringBean) context.getBean("helloWorld");
bean.show();
context.close();
}
}
自動検出
上のサンプルではXMLでマッパーとsqlSessionFactoryを関連付けましたが、下のサンプルでは自動で行います。上のサンプルから修正するソースだけ載せます。
SpringTest.xml
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mybatis="http://mybatis.org/schema/mybatis-spring"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.2.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.2.xsd
http://mybatis.org/schema/mybatis-spring
http://mybatis.org/schema/mybatis-spring.xsd">
<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName"
value="org.postgresql.Driver" />
<property name="url"
value="jdbc:postgresql://localhost:5432/postgres" />
<property name="username" value="postgres" />
<property name="password" value="ps" />
</bean>
<bean id="sqlSessionFactory"
class="org.mybatis.spring.SqlSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="mapperLocations"
value="C:\\eclipseee\\workspace\\springTest\\resource\\sql.xml" />
</bean>
<mybatis:scan base-package="spring.test" />
<bean id="helloWorld" class="spring.test.SpringBean">
</bean>
</beans>
SpringBean.java
package spring.test;
import java.util.List;
import org.springframework.beans.factory.annotation.Autowired;
public class SpringBean {
@Autowired
private UserMapper userMapper;
public void show() {
List<User> list = userMapper.getUserList();
for (User user : list) {
System.out.println(user.getId() + "-" + user.getName());
}
}
}
ページのトップへ戻る