【SpringBoot 实战】之整合 mybatis plus 2.0

本贴最后更新于 2186 天前,其中的信息可能已经渤澥桑田

mybatis plus 是对 mybatis 的增强,自从用了 mybatis plus ,开发效率更快了。

今天来讲讲 SpringBoot 整合 mybatis plus。示例实现了:ActiveRecord、代码生成、分页、公共字段自动填充、逻辑删除、注入自定义 SQL、多租户 SQL 解析器功能。本教程使用的是 mybatis plus2.x 版本。

这边列出主要的配置和类,具体的项目可以查看源码。

整体结构

imagepng

pom 配置

<?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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>

	<groupId>com.cimu</groupId>
	<artifactId>mybatisplus2</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<packaging>jar</packaging>

	<name>mybatisplus2</name>
	<description>mybatisPlus2.0 project for Spring Boot</description>

	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.1.0.RELEASE</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>

	<properties>
		<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
		<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
		<java.version>1.8</java.version>
	</properties>

	<dependencies>
		<dependency>
			<groupId>com.baomidou</groupId>
			<artifactId>mybatis-plus-boot-starter</artifactId>
			<version>2.2.0</version>
		</dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity</artifactId>
            <version>1.7</version>
        </dependency>

		<dependency>
			<groupId>mysql</groupId>
			<artifactId>mysql-connector-java</artifactId>
			<scope>runtime</scope>
		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>
	</dependencies>

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>


</project>

MybatisPlusConfig 类:

@Configuration
@MapperScan("com.cimu.mybatisplus2.mapper*")
public class MybatisPlusConfig {

    /**
 * mybatis-plus SQL执行效率插件【生产环境可以关闭】 */  @Bean
  public PerformanceInterceptor performanceInterceptor() {
        return new PerformanceInterceptor();
  }

    /**
 * mybatis-plus分页插件
  * 文档:http://mp.baomidou.com
  */
  @Bean
  public PaginationInterceptor paginationInterceptor() {
        PaginationInterceptor paginationInterceptor = new PaginationInterceptor();
  paginationInterceptor.setLocalPage(true);// 开启 PageHelper 的支持
 /* * 【测试多租户】 SQL 解析处理拦截器 * 这里固定写成住户 1 实际情况你可以从cookie读取,因此数据看不到 【 麻花藤 】 这条记录( 注意观察 SQL ) */  List sqlParserList = new ArrayList<>();
  TenantSqlParser tenantSqlParser = new TenantSqlParser();
  tenantSqlParser.setTenantHandler(new TenantHandler() {
            @Override
  public Expression getTenantId() {
                return new LongValue(2L);
  }
            @Override
  public String getTenantIdColumn() {
                return "company";
  }
            @Override
  public boolean doTableFilter(String tableName) {
                // 这里可以判断是否过滤表
  return !"user".equals(tableName);
  }
        });
  sqlParserList.add(tenantSqlParser);
  paginationInterceptor.setSqlParserList(sqlParserList);
 return paginationInterceptor;
  }

    @Bean
  public MetaObjectHandler metaObjectHandler() {
        return new SolarMetaObjectHandler();
  }

    /**
 * 注入主键生成器 */  @Bean
  public IKeyGenerator dbKeyGenerator() {
        return new H2KeyGenerator();
  }

    /**
 * 注入sql注入器 */  @Bean
  public ISqlInjector sqlInjector() {
        return new MySqlInjector();
  }

    @Bean
  public OptimisticLockerInterceptor optimisticLockerInterceptor() {
        return new OptimisticLockerInterceptor();
  }

}

自定义方法
MySqlInjector 类

public class MySqlInjector extends LogicSqlInjector {

    @Override
  public void inject(Configuration configuration, MapperBuilderAssistant builderAssistant, Class mapperClass,
  Class modelClass, TableInfo table) {
        /* 添加一个自定义方法 */
  deleteAll(mapperClass, modelClass, table);
  }

    public void deleteAll(Class mapperClass, Class modelClass, TableInfo table) {
        /* 执行 SQL ,动态 SQL 参考类 SqlMethod */
  String sql = "delete from " + table.getTableName();

  /* mapper 接口方法名一致 */
  String method = "deleteAll";
  SqlSource sqlSource = languageDriver.createSqlSource(configuration, sql, modelClass);
 this.addDeleteMappedStatement(mapperClass, method, sqlSource);
  }

}

自动填充配置类:

public class SolarMetaObjectHandler extends MetaObjectHandler {

    protected final static Logger logger = LoggerFactory.getLogger(SolarMetaObjectHandler.class);
 private static final String CREATE_TIME = "createTime";
 private static final String UPDATE_TIME = "updateTime";

  @Override
  public void insertFill(MetaObject metaObject) {
        logger.info("新增的时候干点不可描述的事情");
  Date now = new Date();
  Object createTimeObj = getFieldValByName(CREATE_TIME, metaObject);
 if (null == createTimeObj) {
            setFieldValByName(CREATE_TIME, now, metaObject);
  }
        preUpdate(metaObject, now);
  }

    @Override
  public void updateFill(MetaObject metaObject) {
        logger.info("更新的时候干点不可描述的事情");
  Date now = new Date();
  preUpdate(metaObject, now);
  }

    /**
 * 封装更新的统一处理 * * @param metaObject MetaObject
 * @param now Date
 */  private void preUpdate(MetaObject metaObject, Date now) {
        //强制维护时间
  setFieldValByName(UPDATE_TIME, now, metaObject);
  }

实体类 user:

public class User extends Model{

    /**
 * 主键ID */  
 @TableId("id")
    private Long id;
  /**
 * 真实名称 */  
 private String realName;
  /**
 * 手机号码 */  
 private String mobile;
  /**
 * 密码 */  
 private String password;
  /**
 * 创建日期 */  
 @TableField(fill = FieldFill.INSERT)
    private Date createTime;
  /**
 * 修改日期 */  
 @TableField(fill = FieldFill.INSERT_UPDATE)
    private Date updateTime;
  /**
 * 删除标记 1:删除;0:未删除 */  
 @TableLogic
  private String delFlag;
  @Version
  private Integer version;

 private Integer company;

 ...省略get/set方法

    @Override
  protected Serializable pkVal() {
        return this.id;
  }

}

UserMapper 接口要继承 BaseMapper<User> 类:
imagepng

UserService 接口要继承 IService<User> 类:
imagepng

UserServiceImpl 类要继承 ServiceImpl<UserMapper, User> 类:
imagepng

配置

application.properties 配置

spring.datasource.type=com.zaxxer.hikari.HikariDataSource
spring.datasource.url= jdbc:mysql://127.0.0.1:3306/test?useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=Asia/Shanghai
spring.datasource.username=root
spring.datasource.password=
spring.datasource.driver-class-name = com.mysql.jdbc.Driver

mybatis-plus.global-config.refresh-mapper= true
mybatis-plus.configuration.map-underscore-to-camel-case=true
mybatis-plus.global-config.logic-delete-value=1
mybatis-plus.global-config.logic-not-delete-value=0
mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl
mybatis-plus.global-config.sql-parser-cache=true

单元测试

Mybatisplus2ApplicationTests 是单元测试类,里面有一些测试方法。

源码地址

  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1063 引用 • 3454 回帖 • 189 关注
  • Spring

    Spring 是一个开源框架,是于 2003 年兴起的一个轻量级的 Java 开发框架,由 Rod Johnson 在其著作《Expert One-On-One J2EE Development and Design》中阐述的部分理念和原型衍生而来。它是为了解决企业应用开发的复杂性而创建的。框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为 JavaEE 应用程序开发提供集成的框架。

    943 引用 • 1460 回帖 • 3 关注
  • MyBatis

    MyBatis 本是 Apache 软件基金会 的一个开源项目 iBatis,2010 年这个项目由 Apache 软件基金会迁移到了 google code,并且改名为 MyBatis ,2013 年 11 月再次迁移到了 GitHub。

    170 引用 • 414 回帖 • 387 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
chaigx
欢迎关注我的公众号:程序之声。有些文章没办法同步过来,访问个人博客:http://www.chaiguanxin.com 杭州