创建boot工程 然后导入mybatisyilai与数据源依赖

<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-boot-starter</artifactId>
    <version>3.4.1</version>
</dependency>
<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>druid</artifactId>
    <version>1.1.16</version>
</dependency>

配置文件导入数据源 并开启日志

MP 大于等于 索引失效 mp大于0 tp_字段

 

 

在dao层接口上加入@Mapper注解 并继承BaseMapper<T>

Mp的CRUD操作

MP 大于等于 索引失效 mp大于0 tp_字段_02

 

 Lombok插件 是一个非常好的插件直接可以生成get set 等等

1导入对应依赖

<dependency>
    <groupId>org.projectlombok</groupId>
    <artifactId>lombok</artifactId>
    <version>1.18.12</version>
</dependency>

2@Data 放在实体类上的 就直接不用写以前的getset等等方法 但是@data注解不提供构造方法

 

mp提供了一些基础的sql方法 我们可以直接用

其中分页比较特殊

  1 在使用分页之前呢我们先要配置一下mp的拦截器 要不然是是用不了分页的

MP 大于等于 索引失效 mp大于0 tp_Source_03

 

 2执行分页查询 (mp提供的selectPage方法就是分页查询的方法 其中参数为Ipage的对象 查询条件)

MP 大于等于 索引失效 mp大于0 tp_乐观锁_04

 

 mp中得QueryWrapper查询条件为(dql)

MP 大于等于 索引失效 mp大于0 tp_乐观锁_05

 

查询方法有三种(推荐使用第三种)

lt()表示小于

gt()表示大于

le()表示小于等于

ge()表示大于等于

 

MP 大于等于 索引失效 mp大于0 tp_乐观锁_06

 

 

组合条件

并且的关系就直接" . "就行了

或者的话用 or()

MP 大于等于 索引失效 mp大于0 tp_字段_07

 

 null值处理

在这之前呢 我们要了解一个实体类只能get一个值(只能定义上限或者下限) 如果我们有需求获取在数值期间的话就可以在定义一个querry类中需要的另外一个限定 

MP 大于等于 索引失效 mp大于0 tp_乐观锁_08

 

 

MP 大于等于 索引失效 mp大于0 tp_MP 大于等于 索引失效_09

 

 

查询投影(就是想获取那个字段的信息)

如果要是聚合函数类型 要用QuerryWrapper<T> 接口 lam那个接口是不好使的

MP 大于等于 索引失效 mp大于0 tp_乐观锁_10

 

 

多条件查询有哪些组合?

 

MP 大于等于 索引失效 mp大于0 tp_Source_11

 

 eq这个方法就是用于比对 只有相同才可以往下走

between 就是在什么之间

like就是模糊查询用到的

MP 大于等于 索引失效 mp大于0 tp_Source_12

 

 

MP 大于等于 索引失效 mp大于0 tp_字段_13

 

 字段映射和表名映射

字段映射的意思就是 sql数据库中的字段名字跟java代码的变量名不同  (sql语句中是brand_name java代码中的是brandName)

@tablefiled

MP 大于等于 索引失效 mp大于0 tp_Source_14

 

 

MP 大于等于 索引失效 mp大于0 tp_Source_15

 

 表名映射

@tableName

MP 大于等于 索引失效 mp大于0 tp_乐观锁_16

 

 

DML编程控制

id生成策略

雪花算法:(面试可能会问)

MP 大于等于 索引失效 mp大于0 tp_Source_17

 

 

MP 大于等于 索引失效 mp大于0 tp_Source_18

 

MP 大于等于 索引失效 mp大于0 tp_MP 大于等于 索引失效_19

 

 

 

批量删除

MP 大于等于 索引失效 mp大于0 tp_MP 大于等于 索引失效_20

 

逻辑删除与乐观锁都要先在sql数据表中加入对应得字段 并赋予默认值 

 

逻辑删除(

(先在sql中加一个deleted的字段 默认值为0 然后再在user类中添加注解)或使用全局定义一下子也行
* 就是将增加了一个数据库表中的字段(delete) 然后用这个字段的值来表示删除还是未删除
* (value表示(默认值) 在职)
* (delete 表示删除 以离职 )

)

 

MP 大于等于 索引失效 mp大于0 tp_MP 大于等于 索引失效_21

 

 

MP 大于等于 索引失效 mp大于0 tp_Source_22

 

 乐观锁(

乐观锁(可以同时执行 并不上锁 因为我很乐观 但结果时候只能成功一个因为sql中的version的值已经改变)
* @version (现在sql中加一个version的字段默认值为1 然后再user类中添加对应的成员变量 然后在其上方加注解
* 在config类中添加拦截器OptimisticLockerInnerInterceptor()与分页添加拦截器方法一致  )
* 注 使用乐观锁之前我们必须要获取version的值才能进行修改
* 解决了高并发问题

)

MP 大于等于 索引失效 mp大于0 tp_MP 大于等于 索引失效_23

 

 

MP 大于等于 索引失效 mp大于0 tp_MP 大于等于 索引失效_24

 代码生成器

第一步:创建SpringBoot工程,添加代码生成器相关依赖,其他依赖自行添加

<!--代码生成器-->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
    <version>3.4.1</version>
</dependency><!--velocity模板引擎-->
<dependency>
    <groupId>org.apache.velocity</groupId>
    <artifactId>velocity-engine-core</artifactId>
    <version>2.3</version>
</dependency>第二步:编写代码生成器类
package com.itheima;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;public class Generator {
    public static void main(String[] args) {
        //1. 创建代码生成器对象,执行生成代码操作
        AutoGenerator autoGenerator = new AutoGenerator();        //2. 数据源相关配置:读取数据库中的信息,根据数据库表结构生成代码
        DataSourceConfig dataSource = new DataSourceConfig();
        dataSource.setDriverName("com.mysql.cj.jdbc.Driver");
        dataSource.setUrl("jdbc:mysql://localhost:3306/mybatisplus_db?serverTimezone=UTC");
        dataSource.setUsername("root");
        dataSource.setPassword("root");
        autoGenerator.setDataSource(dataSource);         //3. 执行生成操作
        autoGenerator.execute();
    }
}第三步 开发者自定义配置
3.1设置全局配置
//设置全局配置
GlobalConfig globalConfig = new GlobalConfig();
globalConfig.setOutputDir(System.getProperty("user.dir")+"/mybatisplus_04_generator/src/main/java");    //设置代码生成位置
globalConfig.setOpen(false);    //设置生成完毕后是否打开生成代码所在的目录
globalConfig.setAuthor("黑马程序员");    //设置作者
globalConfig.setFileOverride(true);     //设置是否覆盖原始生成的文件
globalConfig.setMapperName("%sDao");    //设置数据层接口名,%s为占位符,指代模块名称
globalConfig.setIdType(IdType.ASSIGN_ID);   //设置Id生成策略
autoGenerator.setGlobalConfig(globalConfig);3.2设置包名相关配置
//设置包名相关配置
PackageConfig packageInfo = new PackageConfig();
packageInfo.setParent("com.aaa");   //设置生成的包名,与代码所在位置不冲突,二者叠加组成完整路径
packageInfo.setEntity("domain");    //设置实体类包名
packageInfo.setMapper("dao");   //设置数据层包名
autoGenerator.setPackageInfo(packageInfo);3.3策略设置
//策略设置
StrategyConfig strategyConfig = new StrategyConfig();
strategyConfig.setInclude("tbl_user");  //设置当前参与生成的表名,参数为可变参数
strategyConfig.setTablePrefix("tbl_");  //设置数据库表的前缀名称,模块名 = 数据库表名 - 前缀名  例如: User = tbl_user - tbl_
strategyConfig.setRestControllerStyle(true);    //设置是否启用Rest风格
strategyConfig.setVersionFieldName("version");  //设置乐观锁字段名
strategyConfig.setLogicDeleteFieldName("deleted");  //设置逻辑删除字段名
strategyConfig.setEntityLombokModel(true);  //设置是否启用lombok
autoGenerator.setStrategy(strategyConfig);