Spring 整合 MyBatis的實(shí)現(xiàn)步驟
MyBatis 是一款常用的持久層框架,使得程序能夠以調(diào)用方法的方式執(zhí)行某個(gè)指定的SQL,將執(zhí)行SQL的底層邏輯進(jìn)行封裝。多數(shù)與Spring結(jié)合使用,本文討論Spring如何整合Mybatis。

Spring 整合 MyBatis 可以實(shí)現(xiàn)讓數(shù)據(jù)庫連接,事務(wù)管理,實(shí)例化對象的創(chuàng)建與依賴關(guān)系等都統(tǒng)一由 Spring 負(fù)責(zé),以及數(shù)據(jù)庫的增刪改查操作由 spring-mybatis 整合包提供的 SqlSessionTemplate 對象來操作,或者利用整合包掃描接口,依據(jù) Mapper 映射文件直接創(chuàng)建代理實(shí)現(xiàn)類,無須程序員手工實(shí)現(xiàn)接口,大大簡化了開發(fā)流程。SpringMVC 本來就是 Spring 框架的一部分,這兩者無須再做整合,所以 SSM 整合的關(guān)鍵就是Spring對MyBatis的整合,三大框架整合完成后,將以 Spring 為核心,調(diào)用有關(guān)資源,高效運(yùn)作。
一、Spring 項(xiàng)目整體目錄結(jié)構(gòu)

二、Spring 整合 MyBatis 開發(fā)環(huán)境
Spring 整合 MyBatis 開發(fā)環(huán)境除了需要 Spring 的jar包和 MyBatis 的jar包,還需要 Spring 與 MyBatis 整合的中間件 mybatis-spring-xxx.jar,此外還需要數(shù)據(jù)庫驅(qū)動(dòng)jar包 mysql-connector-java-xxx.jar。
三、Mapper 接口無實(shí)現(xiàn)類開發(fā)整合
項(xiàng)目案例:Spring + MyBatis 實(shí)現(xiàn)對 user 數(shù)據(jù)庫的查詢。
實(shí)現(xiàn)步驟:
【1】創(chuàng)建一個(gè) Maven 項(xiàng)目,然后再 pom.xml 文件中添加相關(guān)依賴
<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>cn.kgc.sm</groupId>
<artifactId>spring06</artifactId>
<version>1.0-SNAPSHOT</version>
<packaging>jar</packaging>
<name>spring06</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<!--測試工具-->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.12</version>
<scope>test</scope>
</dependency>
<!--mysql驅(qū)動(dòng)-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.47</version>
</dependency>
<!--druid-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.2.9</version>
</dependency>
<!--mybatis-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.5.9</version>
</dependency>
<!--IOC 依賴注入-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.3.9</version>
</dependency>
<!--mybatis&spring 整合包-->
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>2.0.5</version>
</dependency>
<!--aspects 切面-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>5.3.9</version>
</dependency>
<!--jdbc-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.3.9</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-tx</artifactId>
<version>5.3.9</version>
</dependency>
<!--lombok-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.16</version>
</dependency>
<!-- 日志工具-->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<!--mybatis分頁插件-->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.2.1</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.3.9</version>
<scope>test</scope>
</dependency>
</dependencies>
</project>
【2】在 resources —> config 目錄下,創(chuàng)建數(shù)據(jù)庫配置文件 jdbc.properties
jdbc.driver=com.mysql.jdbc.Driver jdbc.url=jdbc:mysql:///java2218?serverTimezone=UTC&useSSL=false&characterEncoding=UTF-8 jdbc.username=root jdbc.password=root
【3】在 resources —> config 目錄下,創(chuàng)建 MyBatis 配置文件 mybatis-config.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>
<setting name="logImpl" value="LOG4J"/>
<setting name="mapUnderscoreToCamelCase" value="true"/>
<!--全局開啟二級緩存-->
<setting name="cacheEnabled" value="true"/>
</settings>
<!--配置mybatis分頁插件-->
<plugins>
<plugin interceptor="com.github.pagehelper.PageInterceptor">
<!-- 配置mysql方言 -->
<property name="helperDialect" value="mysql" />
<!-- 設(shè)置為true時(shí),如果pageSize=0就會(huì)查詢出全部的結(jié)果 -->
<property name="pageSizeZero" value="true" />
<!-- 3.3.0版本可用,分頁參數(shù)合理化,默認(rèn)false禁用 -->
<!-- 啟用合理化時(shí),如果pageNum<1會(huì)查詢第一頁,如果pageNum>pages會(huì)查詢最后一頁 -->
<!-- 禁用合理化時(shí),如果pageNum<1或pageNum>pages會(huì)返回空數(shù)據(jù) -->
<property name="reasonable" value="true" />
</plugin>
</plugins>
</configuration>【4】在 resources —> config 目錄下,創(chuàng)建 Spring 配置文件 spring-config.xml
<?xml version="1.0" encoding="UTF-8"?>
<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.xsd http://www.springframework.org/schema/context https://www.springframework.org/schema/context/spring-context.xsd">
<!--引入外部數(shù)據(jù)源的配置參數(shù)-->
<context:property-placeholder location="classpath:config/jdbc.properties"></context:property-placeholder>
<!--初始化數(shù)據(jù)庫連接池-->
<bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="${jdbc.driver}"></property>
<property name="url" value="${jdbc.url}"></property>
<property name="username" value="${jdbc.username}"></property>
<property name="password" value="${jdbc.password}"></property>
</bean>
<!--sqlSessionFactory-->
<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
<!--設(shè)置數(shù)據(jù)庫連接池-->
<property name="dataSource" ref="dataSource"></property>
<!--設(shè)置mybatis全局配置文件位置-->
<property name="configLocation" value="config/mybatis-config.xml"></property>
<!--設(shè)置別名的包-->
<property name="typeAliasesPackage" value="cn.kgc.sm"></property>
<!--設(shè)置mapper.xml文件的位置-->
<property name="mapperLocations" value="mapper/*.xml"></property>
</bean>
<!--mapper接口掃描 生成接口代理對象 同時(shí)完成對象的托管-->
<bean class="org.mybatis.spring.mapper.MapperScannerConfigurer">
<property name="basePackage" value="cn.kgc.sm.mapper"></property>
</bean>
<!--開啟包掃描 base-package 設(shè)置需要掃描的包 -->
<context:component-scan base-package="cn.kgc.sm"></context:component-scan>
</beans>
【5】創(chuàng)建實(shí)體類 User
package cn.kgc.sm.entity;
import lombok.Data;
@Data
public class User {
private Integer uId;
private String uName;
private String uPassword;
private Integer uState;
}【6】創(chuàng)建 Mapper 接口 UserMapper
package cn.kgc.sm.mapper;
import cn.kgc.sm.entity.User;
import java.util.List;
public interface UserMapper {
List<User> selectAll();
}【7】創(chuàng)建與 UserMapper 接口映射的 UserMapper.xml 文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"https://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cn.kgc.sm.mapper.UserMapper">
<select id="selectAll" resultType="user">
select * from user
</select>
</mapper>【8】創(chuàng)建 Service 業(yè)務(wù)層接口 UserService
package cn.kgc.sm.service;
import cn.kgc.sm.entity.User;
import cn.kgc.sm.mapper.UserMapper;
import java.util.List;
public interface UserService {
List<User> selectAll();
}【9】創(chuàng)建 UserService 接口的實(shí)現(xiàn)類 UserServiceImpl
package cn.kgc.sm.service.impl;
import cn.kgc.sm.entity.User;
import cn.kgc.sm.mapper.UserMapper;
import cn.kgc.sm.service.UserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class UserServiceImpl implements UserService {
@Autowired
UserMapper userMapper;
@Override
public List<User> selectAll() {
System.out.println("users = ");
List<User> users = userMapper.selectAll();
System.out.println("users = " + users);
return users;
}
}【10】創(chuàng)建測試類
package cn.kgc.sm.mapper;
import cn.kgc.sm.entity.User;
import cn.kgc.sm.service.UserService;
import junit.framework.TestCase;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import java.util.List;
@RunWith(SpringJUnit4ClassRunner.class)
@ContextConfiguration("classpath:config/spring-config.xml")
public class UserMapperTest {
@Autowired
UserService userService;
@Test
public void Test01(){
List<User> users = userService.selectAll();
users.forEach(user -> System.out.println("user = " + user));
// for (User user : users) {
// System.out.println("user = " + user);
// }
}
}運(yùn)行結(jié)果:

到此這篇關(guān)于 Spring 整合 MyBatis的文章就介紹到這了,更多相關(guān) Spring 整合 MyBatis內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Spring事務(wù)&Spring整合MyBatis的兩種方式
- SpringBoot如何整合mybatis-generator-maven-plugin 1.4.0
- SpringBoot整合Mybatis之各種查詢、模糊查詢、批量刪除、動(dòng)態(tài)表名操作
- springboot框架中如何整合mybatis框架思路詳解
- SpringBoot3整合MyBatis出現(xiàn)異常:Property?'sqlSessionFactory'or?'sqlSessionTemplate'?are?required
- SpringBoot整合mybatis/mybatis-plus實(shí)現(xiàn)數(shù)據(jù)持久化的操作
- springboot整合mybatis的超詳細(xì)過程(配置模式+注解模式)
- 詳解SpringBoot整合MyBatis詳細(xì)教程
相關(guān)文章
SpringMVC中轉(zhuǎn)發(fā)與重定向的區(qū)別淺析
這篇文章主要給大家介紹了關(guān)于SpringMVC中轉(zhuǎn)發(fā)與重定向的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12
SpringBoot集成Spring Security用JWT令牌實(shí)現(xiàn)登錄和鑒權(quán)的方法
這篇文章主要介紹了SpringBoot集成Spring Security用JWT令牌實(shí)現(xiàn)登錄和鑒權(quán)的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
Java tomcat手動(dòng)配置servlet詳解
這篇文章主要為大家介紹了tomcat手動(dòng)配置servlet,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2021-11-11
spring學(xué)習(xí)之創(chuàng)建項(xiàng)目 Hello Spring實(shí)例代碼
這篇文章主要介紹了spring學(xué)習(xí)之創(chuàng)建項(xiàng)目 Hello Spring實(shí)例代碼,小編覺得還是挺不錯(cuò)的,具有一定借鑒價(jià)值,需要的朋友可以參考下2018-01-01
Java環(huán)境變量的設(shè)置方法(圖文教程)
想要成功配置Java的環(huán)境變量,那肯定就要安裝JDK,才能開始配置的。2013-05-05

