Day11-MybatisPlus代码生成器

使用MybatisPlus

导入依赖

		
		<dependency>
			<groupId>com.baomidougroupId>
			<artifactId>mybatis-plus-boot-starterartifactId>
			<version>3.4.3version>
		dependency>
        
		<dependency>
			<groupId>com.baomidougroupId>
			<artifactId>mybatis-plus-generatorartifactId>
			<version>3.4.1version>
		dependency>
		<dependency>
			<groupId>org.apache.velocitygroupId>
			<artifactId>velocity-engine-coreartifactId>
			<version>2.3version>
		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 方法控制台输入模块表名回车自动生成对应项目目录中

        /**
         * 

* 读取控制台内容 *

*/
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 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(); } }

Day11-MybatisPlus代码生成器_第1张图片

测试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;

Day11-MybatisPlus代码生成器_第2张图片3.3.0才支持

Day11-MybatisPlus代码生成器_第3张图片

这个方法 不然会爆红

说明:

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

乐观锁:

Day11-MybatisPlus代码生成器_第4张图片

Day11-MybatisPlus代码生成器_第5张图片

Day11-MybatisPlus代码生成器_第6张图片

你可能感兴趣的:(工具,SpringBoot,java,spring,springboot,mybatisplus)