Bootstrap

Day11-MybatisPlus代码生成器

使用MybatisPlus

导入依赖

		<!-- mybatisPlus 启动依赖 -->
		<dependency>
			<groupId>com.baomidou</groupId>
			<artifactId>mybatis-plus-boot-starter</artifactId>
			<version>3.4.3</version>
		</dependency>
        <!--代码自动生成器 -->
		<dependency>
			<groupId>com.baomidou</groupId>
			<artifactId>mybatis-plus-generator</artifactId>
			<version>3.4.1</version>
		</dependency>
		<dependency>
			<groupId>org.apache.velocity</groupId>
			<artifactId>velocity-engine-core</artifactId>
			<version>2.3</version>
		</dependency>

编写生成代码测试类 并配置相关生成规则

package com.fl.mybatisplus;

import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.FieldFill;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;
import com.baomidou.mybatisplus.core.toolkit.StringPool;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.InjectionConfig;
import com.baomidou.mybatisplus.generator.config.*;
import com.baomidou.mybatisplus.generator.config.po.TableFill;
import com.baomidou.mybatisplus.generator.config.po.TableInfo;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
import org.junit.platform.commons.util.StringUtils;

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

/**
 * Created with IntelliJ IDEA.
 *
 * @author: 风离
 * @Date: 2021/07/20/9:43
 * @Description:
 */
public class 代码生成器 {
    // 演示例子,执行 main 方法控制台输入模块表名回车自动生成对应项目目录中

        /**
         * <p>
         * 读取控制台内容
         * </p>
         */
        public static String scanner(String tip) {
            Scanner scanner = new Scanner(System.in);
            StringBuilder help = new StringBuilder();
            help.append("请输入" + tip + ":");
            System.out.println(help.toString());
            if (scanner.hasNext()) {
                String ipt = scanner.next();
                if (StringUtils.isNotBlank(ipt)) {
                    return ipt;
                }
            }
            throw new MybatisPlusException("请输入正确的" + tip + "!");
        }

        public static void main(String[] args) {
            // 代码生成器
            AutoGenerator mpg = new AutoGenerator();

            // 全局配置
            GlobalConfig gc = new GlobalConfig();
            String projectPath = System.getProperty("user.dir");
            gc.setOutputDir(projectPath + "/src/main/java");
            gc.setAuthor("风离");
            gc.setOpen(false);
            gc.setServiceName("%sService");
            gc.setIdType(IdType.ASSIGN_ID);
            gc.setDateType(DateType.ONLY_DATE);

            gc.setSwagger2(true); //实体属性 Swagger2 注解
            mpg.setGlobalConfig(gc);

            // 数据源配置
            DataSourceConfig dsc = new DataSourceConfig();
            dsc.setUrl("jdbc:mysql://localhost:3307/mybatisplus?useUnicode=true&useSSL=false&characterEncoding=utf8");
            // dsc.setSchemaName("public");
            dsc.setDriverName("com.mysql.jdbc.Driver");
            dsc.setUsername("root");
            dsc.setPassword("33333333");
            dsc.setDbType(DbType.MYSQL);
            mpg.setDataSource(dsc);

            // 包配置
            PackageConfig pc = new PackageConfig();
            pc.setModuleName("mybatisPlusGenerator");
            pc.setParent("com.fl");
            pc.setEntity("entity");
            mpg.setPackageInfo(pc);

            // 策略配置

            StrategyConfig strategy = new StrategyConfig();
            strategy.setInclude("stu"); //这里可以设置多张表
            strategy.setNaming(NamingStrategy.underline_to_camel);
            strategy.setColumnNaming(NamingStrategy.underline_to_camel);
//            strategy.setSuperEntityClass("你自己的父类实体,没有就不用设置!");
            strategy.setEntityLombokModel(false);
            strategy.setRestControllerStyle(true);
            //逻辑删除
            strategy.setLogicDeleteFieldName("deleted");
            //自动填充配置
            TableFill createTime=new TableFill("createTime", FieldFill.INSERT);
            TableFill updateTime=new TableFill("updateTime", FieldFill.INSERT_UPDATE);

            List list=new ArrayList();
            list.add(createTime);
            list.add(updateTime);
            strategy.setTableFillList(list);
            // 乐观锁
            strategy.setVersionFieldName("version");
            strategy.setRestControllerStyle(true);
            strategy.setControllerMappingHyphenStyle(true);

            // 公共父类
//            strategy.setSuperControllerClass("你自己的父类控制器,没有就不用设置!");
            // 写于父类中的公共字段
//            strategy.setSuperEntityColumns("id");
//            strategy.setInclude(scanner("表名,多个英文逗号分割").split(","));
//            strategy.setControllerMappingHyphenStyle(true);
//            strategy.setTablePrefix(pc.getModuleName() + "_");
            mpg.setStrategy(strategy);
//
//
//
//
//            // 自定义配置
//            InjectionConfig cfg = new InjectionConfig() {
//                @Override
//                public void initMap() {
//                    // to do nothing
//                }
//            };
//
            // 如果模板引擎是 freemarker
            String templatePath = "/templates/mapper.xml.ftl";
//             //如果模板引擎是 velocity
//             String templatePath = "/templates/mapper.xml.vm";
//
//            // 自定义输出配置
//            List<FileOutConfig> focList = new ArrayList<>();
//            // 自定义配置会被优先输出
//            focList.add(new FileOutConfig(templatePath) {
//                @Override
//                public String outputFile(TableInfo tableInfo) {
//                    // 自定义输出文件名 , 如果你 Entity 设置了前后缀、此处注意 xml 的名称会跟着发生变化!!
//                    return projectPath + "/src/main/resources/mapper/" + pc.getModuleName()
//                            + "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;
//                }
//            });
//        /*
//        cfg.setFileCreate(new IFileCreate() {
//            @Override
//            public boolean isCreate(ConfigBuilder configBuilder, FileType fileType, String filePath) {
//                // 判断自定义文件夹是否需要创建
//                checkDir("调用默认方法创建的目录,自定义目录用");
//                if (fileType == FileType.MAPPER) {
//                    // 已经生成 mapper 文件判断存在,不想重新生成返回 false
//                    return !new File(filePath).exists();
//                }
//                // 允许生成模板文件
//                return true;
//            }
//        });
//        */
//            cfg.setFileOutConfigList(focList);
//            mpg.setCfg(cfg);
//
//            // 配置模板
//            TemplateConfig templateConfig = new TemplateConfig();
//
//            // 配置自定义输出模板
//            //指定自定义模板路径,注意不要带上.ftl/.vm, 会根据使用的模板引擎自动识别
//            // templateConfig.setEntity("templates/entity2.java");
//            // templateConfig.setService();
//            // templateConfig.setController();
//
//            templateConfig.setXml(null);
//            mpg.setTemplate(templateConfig);
//
//
//            mpg.setTemplateEngine(new FreemarkerTemplateEngine());
            mpg.execute();
        }

    }


测试MybatisPlus所提供的方法

package com.fl.mybatisplus;




import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.fl.mybatisplus.entity.Stu;
import com.fl.mybatisplus.mapper.StuMapper;
import com.fl.mybatisplus.service.StuService;
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.Arrays;
import java.util.HashMap;
import java.util.Map;


@SpringBootTest
@RunWith(SpringRunner.class)
public class MybatisPlusApplicationTests {
    @Test //条件工作区 QueryWrapper
    public void testQueryWrapper(){
        QueryWrapper<Stu> queryWrapper=new QueryWrapper<>();
        queryWrapper.select("name");
        System.out.println(stuMapper.selectCount(queryWrapper));
    }
    @Test //测试逻辑删除 deleted=0 ---> deleted=1 //数据库表中有deleted 这个字段
    public void testDelete(){
         stuMapper.deleteById(2);
    }

    @Test //测试批量查询
    public void testQuery(){
        stuMapper.selectBatchIds(Arrays.asList(1,2,3)).forEach(stu -> System.out.println(stu));
    }
    @Test //按条件查询 map 操作 
    public void testMap(){
        Map map=new HashMap();
        map.put("id",1);
        System.out.println(stuMapper.selectByMap(map));
    }
    @Test //测试分页查询
    public void test分页查询(){
        //第几页 有几条
        IPage<Stu> page=new Page<>(1,3);
        stuMapper.selectPage(page,null);
        page.getRecords().forEach(stu -> System.out.println(stu));
        System.out.println(page.getTotal());
    }

	@Test //测试乐观锁 成功 version 版本+1
	public void testL(){

		Stu stu1 = stuMapper.selectById(1);
		stu1.setName("qsfddswe");
		stuMapper.updateById(stu1);

	}

    @Test //测试乐观锁 成功 version 版本+1 否则版本保持第一次增加后的版本 不会增加两次 第二次不会生效
    public void testL2(){
        Stu stu =stuMapper.selectById(1);
        stu.setName("flya");
        Stu stu1 = stuMapper.selectById(1);
        stu1.setName("qsfddswe");
        stuMapper.updateById(stu1);
        stuMapper.updateById(stu);

    }

	@Autowired
	StuMapper stuMapper;

	@Test
	public void testSelect() {
		Stu stu=new Stu();
		stu.setName("sadfs");

		System.out.println(stuMapper.insert(stu));
		

	}
}

表创建时间与更新时间


 @TableField(fill = FieldFill.INSERT) //插入数据时更新
 private Date createTime;
 @TableField(fill = FieldFill.INSERT_UPDATE) //插入或更新数据时
 private Date updateTime;

3.3.0才支持

这个方法 不然会爆红

说明:

  • 支持的数据类型只有:int,Integer,long,Long,Date,Timestamp,LocalDateTime
  • 整数类型下 newVersion = oldVersion + 1
  • newVersion 会回写到 entity
  • 仅支持 updateById(id)update(entity, wrapper) 方法
  • update(entity, wrapper) 方法下, wrapper 不能复用!!!

乐观锁:

;