Mybatis generator和mybatis-plus

news/2025/3/14 17:06:26/

一 Mybatis generator的实现

实现方法一:

依赖+配置文件+运行实现类

1.依赖

    <!-- MyBatis 生成器 --><dependency><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-core</artifactId><version>1.3.3</version></dependency>

2.配置文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE generatorConfigurationPUBLIC "-//mybatis.org//DTD MyBatis Generator Configuration 1.0//EN""http://mybatis.org/dtd/mybatis-generator-config_1_0.dtd">
<generatorConfiguration><!-- 配置文件,放在resource目录下即可 --><!--数据库驱动个人配置--><classPathEntrylocation="D:\IDEAWork\mall\src\main\resources\mysql-connector-java-8.0.18.jar"/><context id="MysqlTables" targetRuntime="MyBatis3"><property name="autoDelimitKeywords" value="true"/><!--可以使用``包括字段名,避免字段名与sql保留字冲突报错--><property name="beginningDelimiter" value="`"/><property name="endingDelimiter" value="`"/><!-- optional,旨在创建class时,对注释进行控制 --><commentGenerator><property name="suppressDate" value="true"/><property name="suppressAllComments" value="true"/></commentGenerator><!--数据库链接地址账号密码--><jdbcConnection driverClass="com.mysql.cj.jdbc.Driver"connectionURL="jdbc:mysql://127.0.0.1:3306/imooc_mall?useUnicode=true&amp;characterEncoding=utf8&amp;autoReconnect=true&amp;useSSL=false&amp;serverTimezone=Asia/Shanghai"userId="root"password="123456"><property name="nullCatalogMeansCurrent" value="true"/></jdbcConnection><!-- 非必需,类型处理器,在数据库类型和java类型之间的转换控制--><javaTypeResolver><property name="forceBigDecimals" value="false"/></javaTypeResolver><!--生成Model类存放位置--><javaModelGenerator targetPackage="com.imooc.mall.model.pojo"targetProject="src/main/java"><!-- 是否允许子包,即targetPackage.schemaName.tableName --><property name="enableSubPackages" value="true"/><!-- 是否对类CHAR类型的列的数据进行trim操作 --><property name="trimStrings" value="true"/><!-- 建立的Model对象是否 不可改变  即生成的Model对象不会有 setter方法,只有构造方法 --><property name="immutable" value="false"/></javaModelGenerator><!--生成mapper映射文件存放位置--><sqlMapGenerator targetPackage="mappers" targetProject="src/main/resources"><property name="enableSubPackages" value="true"/></sqlMapGenerator><!--生成Dao类存放位置--><javaClientGenerator type="XMLMAPPER" targetPackage="com.imooc.mall.model.dao"targetProject="src/main/java"><property name="enableSubPackages" value="true"/></javaClientGenerator><!--生成对应表及类名--><table schema="root" tableName="imooc_mall_cart" domainObjectName="Cart"enableCountByExample="false"enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false"selectByExampleQueryId="false"></table><table tableName="imooc_mall_category" domainObjectName="Category" enableCountByExample="false"enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false"selectByExampleQueryId="false"></table><table tableName="imooc_mall_order" domainObjectName="Order" enableCountByExample="false"enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false"selectByExampleQueryId="false"></table><table tableName="imooc_mall_order_item" domainObjectName="OrderItem"enableCountByExample="false"enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false"selectByExampleQueryId="false"></table><table tableName="imooc_mall_product" domainObjectName="Product" enableCountByExample="false"enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false"selectByExampleQueryId="false"></table><table tableName="imooc_mall_user" domainObjectName="User" enableCountByExample="false"enableUpdateByExample="false" enableDeleteByExample="false" enableSelectByExample="false"selectByExampleQueryId="false"></table></context>
</generatorConfiguration>

3.实现类

package com.macro.mall.tiny.mbg;import org.mybatis.generator.api.MyBatisGenerator;
import org.mybatis.generator.config.Configuration;
import org.mybatis.generator.config.xml.ConfigurationParser;
import org.mybatis.generator.internal.DefaultShellCallback;import java.io.InputStream;
import java.util.ArrayList;
import java.util.List;/*** 用于生产MBG的代码* Created by macro on 2018/4/26.*/
public class Generator {public static void main(String[] args) throws Exception {//MBG 执行过程中的警告信息List<String> warnings = new ArrayList<String>();//当生成的代码重复时,覆盖原代码boolean overwrite = true;//读取我们的 MBG 配置文件InputStream is = Generator.class.getResourceAsStream("/generatorConfig.xml");ConfigurationParser cp = new ConfigurationParser(warnings);Configuration config = cp.parseConfiguration(is);is.close();DefaultShellCallback callback = new DefaultShellCallback(overwrite);//创建 MBGMyBatisGenerator myBatisGenerator = new MyBatisGenerator(config, callback, warnings);//执行生成代码myBatisGenerator.generate(null);//输出警告信息for (String warning : warnings) {System.out.println(warning);}}
}

实现方法二:

插件+配置文件+运行插件

1.插件

<plugin><groupId>org.mybatis.generator</groupId><artifactId>mybatis-generator-maven-plugin</artifactId><version>1.3.7</version><configuration><verbose>true</verbose><overwrite>true</overwrite></configuration>
</plugin>

2.配置文件同上

3.右边maven点击运行插件

二 mybatis-plus的实现

(1)引入依赖

        <dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.0.5</version></dependency><!--        mysql--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId></dependency>

(2)手动创建mapper和pojo类

此处创建的mapper接口需要实现BaseMapper接口,才可以使用默认的CRUD方法Mybatis generator则不用实现接口,自动就写了接口的方法

public interface UserMapper extends BaseMapper<User> {
}

注意:不管用哪个都要在启动类上加mapper扫描

@MapperScan(basePackages = “com.imooc.mall.model.dao”)//告诉Mapper接口在哪,不然会报错说不知道

(3)输出日志

mybatis-plus.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

在这里插入图片描述

(4)mybatis-plus的主键策略

可以在pojo的主键上添加注解,进行指定主键指定主键策略
在这里插入图片描述

  • AUTO:自动
  • INPUT:手动输入
  • NONE:不使用MP的主键策略
  • UUID:随机生成UUID作为主键
  • ID_WORKER:根据算法生成全局序列(数字类型)
  • ID_WORKER_STR:根据算法生成全局序列(字符串类型)

如果不想给每个POJO都配置自增属性,也可以只写@TableId注解,然后自增策略写在配置文件

# 主键自增
mybatis-plus.global-config.db-config.id-type=auto

(5)MP的自动填充

比如创建时间和更新时间需要自动填充

做法:
1.在POJO属性上进行注释(说明什么时候自动添加)
在这里插入图片描述
2.实现元组件控制器(往什么里添加什么)
在这里插入图片描述

(6)乐观锁和悲观锁

  • 悲观锁:资源被使用,直接锁定,别人用不了
  • 乐观锁:通过版本号进行控制,版本号不对,进行回滚

关系型数据库都是悲观锁,非关系型数据库是乐观锁

MP如何实现乐观锁?
1.POJO和表添加version字段
2.version字段实现自动添加版本(在插入时候,添加默认版本)
3.在配置类添加乐观锁插件的bean
在这里插入图片描述
注意:在执行更新的时候,乐观锁不会生效,必须先查询出来,再更新,此时更新的sql是where id = ? and version = ?

(7)MP实现分页查询

1.配置类中添加分页插件bean

@Bean
public PaginationInterceptor  paginationInterceptor() {        return new PaginationInterceptor();
}
 public IPage<Book> paging(Long category,String order,String author,Integer page, Integer rows) {//Ipage是分页接口,page是具体实现Page<Book> page1 = new Page<Book>(page, rows);QueryWrapper<Book> queryWrapper = new QueryWrapper<Book>();IPage<Book> pageObject = bookMapper.selectPage(page1, queryWrapper);return pageObject;

(8)MP实现逻辑删除

数据并不是直接删除,而是进行更新,修改标记删除的字段

1.添加标记删除的字段
2.为标记删除的字段添加字段添加(插入时默认为未删除0)
3.为字段添加逻辑删除注解
在这里插入图片描述
4.添加配置,为MP指明未删除和删除的表示
在这里插入图片描述
5.添加逻辑删除插件
在这里插入图片描述
6.在执行Mapper的删除操作时候,实际上执行的是update

(9)条件查询构造器Wrapper

在这里插入图片描述

eq:equals,等于
gt:greater than ,大于 >
ge:greater than or equals,大于等于≥
lt:less than,小于<
le:less than or equals,小于等于≤
between:相当于SQL中的BETWEEN
like:模糊匹配。like(“name”,“黄”),相当于SQL的name like ‘%黄%’
likeRight:模糊匹配右半边。likeRight(“name”,“黄”),相当于SQL的name like ‘黄%’
likeLeft:模糊匹配左半边。likeLeft(“name”,“黄”),相当于SQL的name like ‘%黄’
notLike:notLike(“name”,“黄”),相当于SQL的name not like ‘%黄%’
isNull
isNotNull
and:SQL连接符AND
or:SQL连接符OR
in: in(“age",{1,2,3})相当于 age in(1,2,3)
groupBy: groupBy(“id”,“name”)相当于 group by id,name
orderByAsc :orderByAsc(“id”,“name”)相当于 order by id ASC,name ASC
orderByDesc :orderByDesc (“id”,“name”)相当于 order by id DESC,name DESC

(10)mybatis-plus的逆向生成工具

  • 依赖

官网有

    <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><!--mybatis-plus 依赖--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.4.1</version></dependency><!--mybatis-plus 代码生成器依赖--><dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-generator</artifactId><version>3.4.1</version></dependency><!--freemarker 依赖--><dependency><groupId>org.freemarker</groupId><artifactId>freemarker</artifactId></dependency><!--mysql 依赖--><dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><scope>runtime</scope></dependency>
  • 生成器类
package com.liu.generator;import com.baomidou.mybatisplus.annotation.DbType;
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.TableInfo;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;import java.util.ArrayList;
import java.util.List;/*** @author long*/
public class CodeGenerator {public static void main(String[] args) {// 代码生成器AutoGenerator mpg = new AutoGenerator();// 全局配置GlobalConfig gc = new GlobalConfig();//设置代码的生成位置,磁盘的目录String projectPath = System.getProperty("user.dir");gc.setOutputDir(projectPath + "/yeb-server/src/main/java");gc.setAuthor("long");gc.setOpen(false); //生成后是否打开资源管理器gc.setFileOverride(false); //重新生成时文件是否覆盖gc.setBaseResultMap(true); //xml开启 BaseResultMapgc.setBaseColumnList(true); //xml 开启BaseColumnListgc.setServiceName("%sService"); //去掉Service接口的首字母Igc.setSwagger2(true); //开启Swagger2模式mpg.setGlobalConfig(gc);// 数据源配置DataSourceConfig dsc = new DataSourceConfig();dsc.setUrl("jdbc:mysql://localhost:3306/yeb?useUnicode=true&characterEncoding=UTF-8&serverTimezone=GMT%2B8");dsc.setDriverName("com.mysql.cj.jdbc.Driver");dsc.setUsername("root");dsc.setPassword("123456");dsc.setDbType(DbType.MYSQL);mpg.setDataSource(dsc);// 包配置PackageConfig pc = new PackageConfig();pc.setParent("com.hwl").setModuleName("server").setEntity("entity").setMapper("mapper").setService("service").setServiceImpl("service.impl").setController("controller");mpg.setPackageInfo(pc);// 自定义配置InjectionConfig cfg = new InjectionConfig() {@Overridepublic void initMap() {// to do nothing}};// 如果模板引擎是 freemarkerString templatePath = "/templates/mapper.xml.ftl";// 如果模板引擎是 velocity// String templatePath = "/templates/mapper.xml.vm";// 自定义输出配置List<FileOutConfig> focList = new ArrayList<>();// 自定义配置会被优先输出focList.add(new FileOutConfig(templatePath) {@Overridepublic String outputFile(TableInfo tableInfo) {// 自定义输出文件名 , 如果你 Entity 设置了前后缀、此处注意 xml 的名称会跟着发生变化!!return projectPath + "/yeb-server/src/main/resources/mapper/" + tableInfo.getEntityName() + "Mapper"+ StringPool.DOT_XML;}});cfg.setFileOutConfigList(focList);mpg.setCfg(cfg);// 配置模板TemplateConfig templateConfig = new TemplateConfig();templateConfig.setXml(null);mpg.setTemplate(templateConfig);// 策略配置StrategyConfig strategy = new StrategyConfig();strategy.setNaming(NamingStrategy.underline_to_camel) //数据库表映射到实体的命名策略,驼峰命名规则.setTablePrefix("t_") //生成实体时去掉表前缀.setColumnNaming(NamingStrategy.no_change) //数据库表字段映射到实体的命名策略.setEntityLombokModel(true)  //lombok模型.setRestControllerStyle(true) //restful api风格控制器.setControllerMappingHyphenStyle(true); //url中驼峰转连字符mpg.setStrategy(strategy);mpg.setTemplateEngine(new FreemarkerTemplateEngine());//执行代码的生成mpg.execute();}}

(1)代码生成器方法二

1.依赖

        <!-- velocity 模板引擎, Mybatis Plus 代码生成器需要 --><dependency><groupId>org.apache.velocity</groupId><artifactId>velocity-engine-core</artifactId></dependency>

2.生成类
和方法一差不多,就是使用的模板不一样
要修改:

  • 生成的路径:gc.setOutputDir(projectPath + “/service/service_edu/src/main/java”);
  • 主键策略:gc.setIdType(IdType.ID_WORKER_STR); 主键为字符串还是数字?
  • 数据库账号和密码,数据库名字
  • 配置包pc.setModuleName(“serviceedu”); //模块名
    pc.setParent(“com.liu”);
  • 要生成的表strategy.setInclude(“edu_teacher”);//指定表名
package com.liu.serviceedu.Generator;import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.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.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import org.junit.Test;/*** @author* @since 2018/12/13*/
public class CodeGenerator {public static void main(String[] args) {// 1、创建代码生成器AutoGenerator mpg = new AutoGenerator();// 2、全局配置GlobalConfig gc = new GlobalConfig();String projectPath = System.getProperty("user.dir");gc.setOutputDir(projectPath + "/service/service_edu/src/main/java");gc.setAuthor("liu");gc.setOpen(false); //生成后是否打开资源管理器gc.setFileOverride(false); //重新生成时文件是否覆盖gc.setServiceName("%sService");	//去掉Service接口的首字母Igc.setIdType(IdType.ID_WORKER_STR); //主键策略gc.setDateType(DateType.ONLY_DATE);//定义生成的实体类中日期类型gc.setSwagger2(true);//开启Swagger2模式mpg.setGlobalConfig(gc);// 3、数据源配置DataSourceConfig dsc = new DataSourceConfig();dsc.setUrl("jdbc:mysql://localhost:3306/education?serverTimezone=GMT%2B8");dsc.setDriverName("com.mysql.jdbc.Driver");dsc.setUsername("root");dsc.setPassword("123456");dsc.setDbType(DbType.MYSQL);mpg.setDataSource(dsc);// 4、包配置PackageConfig pc = new PackageConfig();
//        com.liu.service_edupc.setModuleName("serviceedu"); //模块名pc.setParent("com.liu");pc.setController("controller");pc.setEntity("entity");pc.setService("service");pc.setMapper("mapper");mpg.setPackageInfo(pc);// 5、策略配置StrategyConfig strategy = new StrategyConfig();strategy.setInclude("edu_teacher");//指定表名strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略strategy.setTablePrefix(pc.getModuleName() + "_"); //生成实体时去掉表前缀strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略strategy.setEntityLombokModel(true); // lombok 模型 @Accessors(chain = true) setter链式操作strategy.setRestControllerStyle(true); //restful api风格控制器strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符mpg.setStrategy(strategy);// 6、执行mpg.execute();}
}

http://www.ppmy.cn/news/792266.html

相关文章

乐高幻影忍者推出十周年复刻经典套装;炸鸡大师Popeyes开设首家南京旗舰店 | 美通企业日报...

今日看点&#xff1a;乐高幻影忍者系列诞生十周年&#xff0c;推出复刻经典套装与时尚联名系列。炸鸡大师Popeyes正式宣布入驻南京。麦德龙中国发布2020可持续发展报告。Cytiva向龙沙集团交付模块化生物工厂。拜耳以医药创新突破推动处方药业务转型。锐思华创携裸眼AR亮相国际消…

mybatis/mybatisplus 一对多查询

1.Controller 定义 需要传入的参数 OntologyEntity paramnew OntologyEntity(); param.setName(name); Page<OntologyEntity> resultPagenew Page<>(pageNumber,pageSize); // 查询分页数据&#xff1a;mybatisplus // param&#xff1a;为查询需要传入的参数可以…

Mybatis -- 使用

目录 官网 依赖 简单使用 Mapper代理方式 字段属性名映射 请求参数 1.普通类型参数 2.多个参数 3.对象参数 4.Map参数 动态参数 IF 判断 Choose判断 特殊字符 插入insert 更新update 删除delete 单个删除 多个删除 参数封装 单个参数 多个参数 一对一查询…

MyBatis的一对多查询

<!-- 一对多关联查询 --> <resultMap id"唯一的标识" type"映射的pojo对象"><id column"表的主键字段或查询语句中的别名字段" jdbcType"字段类型" property"映射pojo对象的主键属性" /><result colu…

MyBatis增强器——Mybatis-Plus

MyBatis增强器——Mybatis-Plus 一、Mybatis-Plus简介1.简介2.特性3.支持数据库4.框架结构 二、入门案例1.开发环境2.创建数据库及表创建表添加数据 3.创建SpringBoot工程4.编写代码 三、基本crud四、常用注解1.TableName通过TableName解决问题通过全局配置解决问题 2.TableId通…

万豪、希尔顿、凯悦、万达、首旅如家旗下酒店年末扎堆开业 | 中国酒店业周刊...

本期焦点&#xff1a;元旦国内酒店预订量是去年1.8倍&#xff0c;三亚春节客房每间限价5900元。深圳湾安达仕、沈阳万豪、重庆两江新区高科希尔顿、陵水碧桂园希尔顿逸林温泉、北京海淀万枫、苏州吴中福朋喜来登、萍乡武功山万达锦华、桂林融创万达嘉华、成都中心、上海静安逸扉…

万豪将在武汉远洋里建奢华五星酒店;Cook’s Club全球首家全套房酒店落户桂林 | 中国酒店周刊...

本期焦点&#xff1a;复星旅文旗下Cook’s Club全球首家全套房酒店下半年于桂林开业。美团或投资东呈国际集团入局酒店行业。佛山南海和华希尔顿逸林酒店开业。万豪将在武汉远洋里建奢华五星酒店。安纳塔拉度假会国内首家品牌推广店于上海开业。 酒店业动态 复星旅文旗下Cook…

MybatisPlus实现高效的多对多查询

1、前置 事先声明一下代码中蕴含了大量的Stream和Lambda表达式操作&#xff0c;还不清楚的小伙伴可以去参考一下Java8新特性Stream流 &#xff0c;而却我是用的是MybatisPlus这方面不清楚的也可以参考一下MybatisPlus基础用法&#xff1b;中间的对象转换除了使用Spring的BeanP…