本教程主要詳細講解SpringBoot整合MyBatis項目高級操作模式,主要使用到@Provider
高級模式進行MyBatis整合開發,本文主要講解Update更新數據操作.
基礎環境
技術 | 版本 |
---|---|
Java | 1.8+ |
SpringBoot | 2.x.x |
MyBatis | 3.5.x |
創建項目
- 初始化項目
mvn archetype:generate -DgroupId=com.edurt.sli.slismpi -DartifactId=spring-learn-integration-springboot-mybatis-provider-update-delete -DarchetypeArtifactId=maven-archetype-quickstart -Dversion=1.0.0 -DinteractiveMode=false
- 修改pom.xml增加MyBatis
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns="http://maven.apache.org/POM/4.0.0"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<parent>
<artifactId>spring-learn-integration-springboot-mybatis-provider</artifactId>
<groupId>com.edurt.sli</groupId>
<version>1.0.0</version>
</parent>
<modelVersion>4.0.0</modelVersion>
<artifactId>spring-learn-integration-springboot-mybatis-provider-update-delete</artifactId>
<name>SpringBoot整合MyBatis教程Provider進階(Update-Delete)</name>
<properties>
<system.java.version>1.8</system.java.version>
<plugin.maven.compiler.version>3.3</plugin.maven.compiler.version>
<springboot.common.version>2.1.3.RELEASE</springboot.common.version>
<springboot.mybatis.common.version>2.1.1</springboot.mybatis.common.version>
<mysql.version>5.1.47</mysql.version>
<lombox.version>1.18.8</lombox.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>${springboot.common.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<version>${springboot.common.version}</version>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>${springboot.mybatis.common.version}</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombox.version}</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>${springboot.common.version}</version>
<configuration>
<fork>true</fork>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<version>${plugin.maven.compiler.version}</version>
<configuration>
<source>${system.java.version}</source>
<target>${system.java.version}</target>
</configuration>
</plugin>
</plugins>
</build>
</project>
mybatis-spring-boot-starter
:該starter是我們使用SpringBoot整合MyBatis的依賴整合包
- 在
src/main/java
目錄下新建com.edurt.sli.slismpu目錄並在該目錄下新建SpringBootMyBatisProviderUpdateIntegration
類文件,在文件輸入以下內容
package com.edurt.sli.slismpu;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.stereotype.Component;
@SpringBootApplication
@Component(value = "com.edurt.sli.slismpu")
public class SpringBootMyBatisProviderUpdateDeleteIntegration {
public static void main(String[] args) {
SpringApplication.run(SpringBootMyBatisProviderUpdateDeleteIntegration.class, args);
}
}
構建SQL文件
在src/main
目錄下新建example.sql文件,鍵入以下內容
create database spring;
use spring;
drop table if exists user;
create table user
(
id int(20) auto_increment,
userName varchar(20),
title varchar(20),
primary key (id)
)
default charset 'utf8';
我們運行該sql文件進行創建數據庫/數據表操作.
配置MyBatis
- 在
/src/main/java/com/edurt/sli/slismpu
目錄下創建config目錄,並在該目錄下新建MyBatisProviderConfig
配置類,鍵入以下代碼
package com.edurt.sli.slismpu.config;
import org.apache.ibatis.session.SqlSessionFactory;
import org.mybatis.spring.SqlSessionFactoryBean;
import org.mybatis.spring.annotation.MapperScan;
import org.mybatis.spring.boot.autoconfigure.ConfigurationCustomizer;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.jdbc.datasource.DataSourceTransactionManager;
import javax.sql.DataSource;
@Configuration
@MapperScan(value = {"com.edurt.sli.slismpu.mapper"})
public class MyBatisProviderConfig {
@Bean(name = "transactionManager")
public DataSourceTransactionManager transactionManager(
@Qualifier("dataSource") DataSource dataSource) {
return new DataSourceTransactionManager(dataSource);
}
@Bean(name = "sqlSessionFactory")
@ConditionalOnMissingBean(name = "sqlSessionFactory")
public SqlSessionFactory sqlSessionFactory(@Qualifier("dataSource") DataSource dataSource) throws Exception {
final SqlSessionFactoryBean sessionFactory = new SqlSessionFactoryBean();
sessionFactory.setDataSource(dataSource);
return sessionFactory.getObject();
}
@Bean
ConfigurationCustomizer mybatisConfigurationCustomizer() {
return configuration -> {
configuration.setMapUnderscoreToCamelCase(Boolean.TRUE);
configuration.setLogPrefix("com.edurt.sli.slismpu");
};
}
}
@MapperScan
註解用於指定我們Mapper文件所在的位置
- 在
/src/main/resources
資源目錄下創建一個application.properties的配置文件,用於數據庫連接配置,鍵入以下內容
server.port=8989
spring.datasource.url=jdbc:mysql://localhost:3306/spring?useSSL=false
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.username=root
spring.datasource.password=123456
配置數據模型
- 在
/src/main/java/com/edurt/sli/slismpu
目錄下創建model目錄,並在該目錄下新建UserModel
實體類,鍵入以下代碼
package com.edurt.sli.slismpu.model;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.ToString;
@Data
@ToString
@AllArgsConstructor
@NoArgsConstructor
public class UserModel {
private Integer id;
private String userName;
private String title;
}
支持數據Update功能
- 在
/src/main/java/com/edurt/sli/slismpu
目錄下創建provider目錄,並在該目錄下新建UserUpdateProvider
類,用於轉換實體與SQL腳本,鍵入以下代碼
package com.edurt.sli.slismpu.provider;
import com.edurt.sli.slismpu.model.UserModel;
import org.apache.ibatis.jdbc.SQL;
import org.springframework.util.ObjectUtils;
public class UserUpdateProvider {
private String tableName = "user";
public String updateModel(UserModel user) {
return new SQL() {{
UPDATE(tableName);
if (!ObjectUtils.isEmpty(user.getTitle())) {
SET(String.join(".", tableName, "name = #{title}"));
}
if (!ObjectUtils.isEmpty(user.getUserName())) {
SET(String.join(".", tableName, "userName = #{userName}"));
}
WHERE("id=#{id}");
}}.toString();
}
}
我們在做數據插入操作的時候使用的是VALUES
,那麼在更新的時候需要使用SET
,不能在使用VALUES
,並且一定要在SET更新的參數加上**=**用於標記,不做膚質標記的話會出現SQL轉換錯誤問題
- 在
/src/main/java/com/edurt/sli/slismpu
目錄下創建mapper目錄,並在該目錄下新建UserUpdateMapper數據表操作映射類,鍵入以下內容
package com.edurt.sli.slismpu.mapper;
import com.edurt.sli.slismpu.model.UserModel;
import com.edurt.sli.slismpu.provider.UserUpdateProvider;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.UpdateProvider;
@Mapper
public interface UserUpdateMapper {
@UpdateProvider(type = UserUpdateProvider.class, method = "updateModel")
Integer updateModel(UserModel model);
}
@UpdateProvider
標記我們使用高級功能type指定Provider類名,method指定的是該類中要使用的哪一個方法
- 接下來我們在
/src/test/java
目錄下新建com.edurt.sli.slismpu目錄,並在該目錄下新建UserUpdateMapperTest測試文件,鍵入以下內容
package com.edurt.sli.slismpu;
import com.edurt.sli.slismpu.mapper.UserUpdateMapper;
import com.edurt.sli.slismpu.model.UserModel;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.autoconfigure.jdbc.AutoConfigureTestDatabase;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
@RunWith(SpringJUnit4ClassRunner.class)
@AutoConfigureTestDatabase(replace = AutoConfigureTestDatabase.Replace.NONE)
@SpringBootTest(
classes = SpringBootMyBatisProviderUpdateDeleteIntegration.class,
webEnvironment = SpringBootTest.WebEnvironment.RANDOM_PORT
)
public class UserUpdateMapperTest {
@Autowired
private UserUpdateMapper userUpdateMapper;
private UserModel user;
@Before
public void before() {
user = new UserModel();
}
@Test
public void testUpdateModel() {
user.setId(1);
user.setTitle("XXXX");
this.userUpdateMapper.updateModel(user);
}
}
批量更新操作,可以自己傳遞List集合使用JDK Stream進行SQL組裝.
注意: 在SET中的數據一定要使用=賦值符號連接,否則會出現SQL轉換錯誤問題
支持數據Delete功能
- 在
com.edurt.sli.slismpu.provider
目錄下新建UserDeleteProvider
類在該類中鍵入以下代碼
package com.edurt.sli.slismpu.provider;
import com.edurt.sli.slismpu.model.UserModel;
import org.apache.ibatis.jdbc.SQL;
import org.springframework.util.ObjectUtils;
public class UserDeleteProvider {
private String tableName = "user";
public String deleteModel(UserModel user) {
return new SQL() {{
DELETE_FROM(tableName);
WHERE("id=#{id}");
}}.toString();
}
}
Mapper和測試同Update一致
拼接SQL
拼接SQL很簡單就是我們將一系列的參數拼接爲SQL字符串.下面是一個例子.
- 修改
UserDeleteProvider
類在該類中鍵入以下代碼支持批量添加數據操作
public String deleteModelByCustomSql(UserModel user) {
StringBuilder builder = new StringBuilder();
builder.append("DELETE FROM ");
builder.append(tableName);
builder.append(" WHERE id = ");
builder.append(user.getId());
return builder.toString();
}
注意: 我們在拼接SQL的時候一定要確保SQL的準確性,主要是每個參數或者關鍵字之間的隔離符號(空格),這也是我們最容易出現錯誤的地方.new SQL()底層也是使用的Buffer進行SQL拼接.
打包文件部署
- 打包數據
mvn clean package -Dmaven.test.skip=true -X
運行打包後的文件即可
java -jar target/spring-learn-integration-springboot-mybatis-provider-update-delete-1.0.0.jar