在 SpringBoot 中引入 MyBatisPlus 之 常规操作

一、前言

近来参与一个电力大数据项目,开发小组决定在 DAO 层使用 MyBatisPlus
——国产、新颖、强大、轻量。
这里写图片描述
官方API地址:http://mp.baomidou.com/#/?id=%E7%AE%80%E4%BB%8B

二、通用 CRUD

通过本项目(表少,数据量大,非常适合)
发现 MyBatisPlus 在 单表CRUD 方面
比原来的的 MyBatis 的有着绝对优势:

VSPSMyBatisMyBatisPlus
代码生成器数据库有些表的字段发声改变① 再次运行逆向工程的代码 ②生成一堆代码,还最好不要动它①只需要修改 Bean 即可(反射实现的)② 生成少量的代码,可以人为新增内容
CRUD无规律特殊时手动写 Mapper 层 sql通过条件构造器,实现零 sql !

下面列出本文相关代码,其他代码如 Druid数据源配置、MyBatisPlus分页配置、sql输出配置,可以到 github 上查看:
https://github.com/larger5/SpringBoot_MybatisPlus.git
这里写图片描述

package com.cun.plus;

import com.baomidou.mybatisplus.mapper.Wrapper;
import com.baomidou.mybatisplus.plugins.Page;
import com.cun.plus.entity.User;
import com.cun.plus.mapper.UserMapper;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;

@RunWith(SpringRunner.class)
@SpringBootTest
public class PlusApplicationTests {

    @Autowired
    private UserMapper userMapper;

    /**
     * 1、增加 insert
     */
    @Test
    public void insertTest() {
        User user = new User();
        user.setUsername("绿茶");
        user.setPassword("lvcha");
        // 返回对数据库影响操作数:1
        Integer insert1 = userMapper.insert(user); // 非空属性才会出现在 sql 中
        // 可以立刻获取插入新记录的 id
        System.out.println(user.getId());
        // 同上
        Integer insert2 = userMapper.insertAllColumn(user); // 所有属性都会出现在 sql 中
        // 同上
        System.out.println(user.getId());
    }

    /**
     * 2、修改 update
     */
    @Test
    public void updateTest() {
        User user = new User();
        user.setId(45);
        user.setUsername("cun");
        //user.setPassword("666");
        // 返回对数据库影响操作数:1
        Integer integer1 = userMapper.updateById(user); // 属性空则不修改
        System.out.println(integer1);
        // 同上
        Integer integer2 = userMapper.updateAllColumnById(user); // 属性空则字段空
        System.out.println(integer2);
    }

    /**
     * 3、查询 select
     */
    @Test
    public void selectTest() {
        // 根据id 查询一条记录
        User user = userMapper.selectById(46);
        System.out.println(user.getUsername());

        ArrayList<Integer> idList = new ArrayList<>();
        idList.add(61);
        idList.add(63);
        // 根据多个id 批量查询
        List<User> users = userMapper.selectBatchIds(idList);
        System.out.println(users.get(0).getUsername() + users.get(1).getUsername());

        User user1 = new User();
        user1.setId(61);
        user1.setUsername("cun");
        // 根据多个条件返回一个对象,若有多个符合条件的记录则将报错
        User user2 = userMapper.selectOne(user1);
        System.out.println(user2.getPassword());

        // 根据多个条件返回对象组,注意Map 中的key 必须和数据库表字段一直
        HashMap<String, Object> columnMap = new HashMap<>();
        columnMap.put("username", "cun");
        List<User> users1 = userMapper.selectByMap(columnMap);
        System.out.println(users1.size());


    }

    /**
     * 4、删除 delete
     */
    @Test
    public void deleteTest() {
        // 根据一个id 删除,返回对数据库影响操作数:1
        Integer integer1 = userMapper.deleteById(65);// 根据id删除一条记录
        System.out.println(integer1);

        ArrayList<Integer> idList = new ArrayList<>(); // 根据id集合批量删除
        idList.add(64);
        idList.add(66);
        // 根据多个id 批量删除,返回对数据库影响操作数:2
        Integer integer2 = userMapper.deleteBatchIds(idList);
        System.out.println(integer2);

        HashMap<String, Object> columnMap = new HashMap<>();
        columnMap.put("username", "cun");
        // 根据多个条件删除,返回对数据库影响操作数
        Integer integer3 = userMapper.deleteByMap(columnMap);
        System.out.println(integer3);
    }

    /**
     * 5、伪分页(获取全部数据再分页)
     */
    @Test
    public void pageTest() {
        // 分页查询,注意如果设置了 PaginationInterceptor 分页插件则会报错,
        List<User> users2 = userMapper.selectPage(new Page<User>(1, 2), null); //当前页、每页大小
        System.out.println(users2.get(0).getUsername() + users2.get(1).getUsername());
        System.out.println(users2.size());
    }


    /**
     * 6、条件构造器
     */
    @Test
    public void wrapperTest(){
        List<User> users = userMapper.selectList(new EntityWrapper<User>()
                .eq("username", "linhongcun")
        );
        System.out.println(users.size());
    }

}

三、代码生成器

上述的代码通过 MyBatisPlsus 自动写好的通用 Mapper 层,在 Service 层里边写相关的业务逻辑
其实,使用了 MyBatisPlus 代码生成器,自动生成 Entity、Dao、Service、Controller 层!
我们通常是在 Controller 层里边写相关的业务逻辑,使用的方法和 Mapper 的类似。

package com.cun.plus;

import com.baomidou.mybatisplus.enums.IdType;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.GlobalConfig;
import com.baomidou.mybatisplus.generator.config.PackageConfig;
import com.baomidou.mybatisplus.generator.config.StrategyConfig;
import com.baomidou.mybatisplus.generator.config.rules.DbType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;

public class MpG {
    public static void main(String[] args) {
        //1. 全局配置
        GlobalConfig config = new GlobalConfig();
        config.setActiveRecord(false) // 是否支持AR模式
                .setAuthor("linhongcun") // 作者
                .setOutputDir("C:\\data\\mp") // 生成路径
                .setFileOverride(true)  // 文件覆盖
                .setIdType(IdType.AUTO) // 主键策略
                .setServiceName("%sService")  // 设置生成的service接口的名字的首字母是否为I
                // IUserService
                .setBaseResultMap(true)
                .setBaseColumnList(true);

        //2. 数据源配置
        DataSourceConfig dsConfig = new DataSourceConfig();
        dsConfig.setDbType(DbType.MYSQL)  // 设置数据库类型
                .setDriverName("com.mysql.jdbc.Driver")
                .setUrl("jdbc:mysql://120.79.197.130:3307/testspring?useSSL=true&verifyServerCertificate=false&allowMultiQueries=true&useUnicode=true&characterEncoding=UTF-8")
                .setUsername("root")
                .setPassword("123");

        //3. 策略配置
        StrategyConfig stConfig = new StrategyConfig();
        stConfig.setCapitalMode(true) //全局大写命名
                .setDbColumnUnderline(true)  // 指定表名 字段名是否使用下划线
                .setNaming(NamingStrategy.underline_to_camel) // 数据库表映射到实体的命名策略
                .setTablePrefix("tb_")
                .setInclude("tb_user");  // 生成的表

        //4. 包名策略配置
        PackageConfig pkConfig = new PackageConfig();
        pkConfig.setParent("com.cun.plus")
                .setMapper("mapper")
                .setService("service")
                .setController("controller")
                .setEntity("entity")
                .setXml("mapper");

        //5. 整合配置
        AutoGenerator ag = new AutoGenerator();
        ag.setGlobalConfig(config)
                .setDataSource(dsConfig)
                .setStrategy(stConfig)
                .setPackageInfo(pkConfig);

        //6. 执行
        ag.execute();
    }
}

四、相关依赖

    // 选择 freemarker 引擎,默认 Veloctiy
    // mpg.setTemplateEngine(new FreemarkerTemplateEngine());
        <!-- mybatis-plus-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>2.3</version>
        </dependency>
        <!-- 代码生成器默认使用如下模版引擎 -->
        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity-engine-core</artifactId>
            <version>2.0</version>
        </dependency>

五、其他

使用 MyBatis 的一个弊端,就是得依靠使用代码生成器,使得逻辑基本写在 controller 层,而不是 service 层,不合时宜。

多表+分页,详见:

最简单的 MyBatis Plus 的多表联接、分页查询实现方法

已标记关键词 清除标记
## 第一次使用Mybatis-plus,在做完配置之后,点击mp:code,生成的代码如下: 很多文件都是包的路径错误,这是什么情况啊,。。。。应该怎么解决呢??? 这里是包的路径import com.baomidou.mybatisplus.annotation.TableId; 生成的是import com.baomidou.mybatisplus.annotations.TableId; ![图片说明](https://img-ask.csdn.net/upload/201811/30/1543546984_436119.png) 这里路径应该为import com.baomidou.mybatisplus.extension.service.IService; 结果生成了import com.baomidou.framework.service.IService; ![图片说明](https://img-ask.csdn.net/upload/201811/30/1543547119_100572.png) 配置文件如下: pom.xml ``` <?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.wuyunfeng</groupId> <artifactId>TestPlus</artifactId> <version>1.0-SNAPSHOT</version> <packaging>war</packaging> <name>TestPlus Maven Webapp</name> <url>http://www.wuyunfeng.com</url> <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding> <maven.compiler.source>1.7</maven.compiler.source> <maven.compiler.target>1.7</maven.compiler.target> <!-- spring版本号 --> <spring.version>4.3.5.RELEASE</spring.version> <!-- mybatis版本号 --> <mybatis.version>3.4.1</mybatis.version> <!-- log4j日志文件管理包版本 --> <slf4j.version>1.7.12</slf4j.version> <log4j.version>1.2.17</log4j.version> </properties> <dependencies> <!-- 单元测试 --> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.11</version> <!-- 表示开发的时候引入,发布的时候不会加载此包 --> <scope>test</scope> </dependency> <!-- java ee包 --> <dependency> <groupId>javax</groupId> <artifactId>javaee-api</artifactId> <version>7.0</version> </dependency> <!-- 导入mybatis-plus包 start --> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus</artifactId> <version>3.0.6</version> </dependency> <dependency> <groupId>org.apache.velocity</groupId> <artifactId>velocity</artifactId> <version>1.7</version> </dependency> <!-- 导入mybatis-plus包 end --> <!-- 数据库驱动 --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.41</version> </dependency> <!-- 导入dbcp的jar包,用来在applicationContext.xml配置数据库 --> <dependency> <groupId>commons-dbcp</groupId> <artifactId>commons-dbcp</artifactId> <version>1.4</version> </dependency> <!-- jstl标签类 --> <dependency> <groupId>jstl</groupId> <artifactId>jstl</artifactId> <version>1.2</version> </dependency> <dependency> <groupId>taglibs</groupId> <artifactId>standard</artifactId> <version>1.1.2</version> </dependency> <!-- log start --> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>${log4j.version}</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>${slf4j.version}</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-log4j12</artifactId> <version>${slf4j.version}</version> </dependency> <!-- log END --> <!-- 格式化对象,方便输出日志 --> <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.6</version> </dependency> <dependency> <groupId>org.codehaus.jackson</groupId> <artifactId>jackson-mapper-asl</artifactId> <version>1.9.13</version> </dependency> <!-- 上传组件包 start --> <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> <version>1.3.1</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.4</version> </dependency> <dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.10</version> </dependency> <!-- 上传组件包 end --> <!-- AL相关添加 --> <dependency> <groupId>net.sourceforge.jexcelapi</groupId> <artifactId>jxl</artifactId> <version>2.6</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi</artifactId> <version>3.8</version> </dependency> <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi-ooxml</artifactId> <version>3.9</version> </dependency> <!-- AL相关添加 --> <!-- https://mvnrepository.com/artifact/net.sourceforge.javacsv/javacsv --> <dependency> <groupId>net.sourceforge.javacsv</groupId> <artifactId>javacsv</artifactId> <version>2.0</version> </dependency> <!-- spring框架包 start --> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-core</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-web</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-tx</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-jdbc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aop</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-oxm</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context-support</artifactId> <version>${spring.version}</version> </dependency> <!-- spring框架包 end --> <!-- spring 新添加的可选包 项目未用到--> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-context</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-expression</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-orm</artifactId> <version>${spring.version}</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-aspects</artifactId> <version>${spring.version}</version> </dependency> </dependencies> <build> <finalName>TestPlus</finalName> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>2.3.2</version> <configuration> <source>1.6</source> <target>1.6</target> </configuration> </plugin> <plugin> <groupId>com.baomidou</groupId> <artifactId>mybatisplus-maven-plugin</artifactId> <version>1.0</version> <configuration> <!-- 输出目录(默认java.io.tmpdir) --> <outputDir>/run/media/ry03/wuyunfeng/workspace/IDEA/TestPlus/src/main/java</outputDir> <!-- 是否覆盖同名文件(默认false) --> <fileOverride>true</fileOverride> <!-- mapper.xml 添加二级缓存配置(默认true) --> <enableCache>false</enableCache> <!-- 开发者名称 --> <author>WuYunfeng</author> <!-- 是否开启 ActiveRecord 模式(默认true) --> <activeRecord>false</activeRecord> <!-- 数据源配置,( **必配** ) --> <dataSource> <driverName>com.mysql.jdbc.Driver</driverName> <url>jdbc:mysql://127.0.0.1:3306/testssm?useUnicode=true&useSSL=false&characterEncoding=utf-8</url> <username>root</username> <password>123456</password> </dataSource> <strategy> <!-- 字段生成策略,四种类型,从名称就能看出来含义: nochange(默认), underline_to_camel,(下划线转驼峰) remove_prefix,(去除第一个下划线的前部分,后面保持不变) remove_prefix_and_camel(去除第一个下划线的前部分,后面转驼峰) --> <naming>underline_to_camel</naming> <!-- 表前缀 --> <tablePrefix>bmd_</tablePrefix> <!--Entity的ID生成策略(默认 id_worker)--> <idGenType>auto</idGenType> <!--自定义超类--> <!--<superServiceClass>com.baomidou.base.BaseService</superServiceClass>--> <!-- 要包含的表 与exclude 二选一配置--> <include> <property>user</property> <!--<property>message</property>--> </include> <!-- 要排除的表 --> <!--<exclude>--> <!--<property>schema_version</property>--> <!--</exclude>--> </strategy> <packageInfo> <!-- 父级包名称,如果不写,下面的service等就需要写全包名(默认com.baomidou) --> <parent>com.wuyunfeng</parent> <!-- service包名(默认service) --> <service>service</service> <!-- serviceImpl包名(默认service.impl) --> <serviceImpl>service.impl</serviceImpl> <!-- entity包名(默认entity) --> <entity>model</entity> <!-- mapper包名(默认mapper) --> <mapper>mapper</mapper> <!-- xml包名(默认mapper.xml) --> <xml>mapper.xml</xml> <!-- controller包名(默认controller) --> <controller>controller</controller> </packageInfo> </configuration> <dependencies> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>5.1.41</version> </dependency> </dependencies> </plugin> </plugins> </build> </project> ```
©️2020 CSDN 皮肤主题: 书香水墨 设计师:CSDN官方博客 返回首页