使用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
不能复用!!!
乐观锁: