学MybatisPlus

1.设置MySql的数据库

XML 复制代码
spring:
  datasource:
    url: jdbc:mysql://127.0.0.1:3306/mp?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&serverTimezone=Asia/Shanghai
    driver-class-name: com.mysql.cj.jdbc.Driver
    username: root
    password: MySQL123
logging:
  level:
    com.itheima: debug
  pattern:
    dateformat: HH:mm:ss

logging : level : com.itheima 是来设置日志的输出模式,debug可以看到MySql的语句。

依赖:mybatis-plus-boot-starter

2.在Mapper中使用:需要在mapper接口中中使用extends BaseMapper<实体类>(一般是简单的)

3.常见注解,一般是来实体类

  1. @TableName
  2. @TableField
  3. @TableId (Auto , Input , Assign_id)

4.常见配置

XML 复制代码
mybatis-plus:
  type-aliases-package: com.itheima.mp.domain.po //实体类
  global-config:
    db-config:
      id-type: auto # 全局id类型为自增长

MySql的手写:

XML 复制代码
mybatis-plus:
  mapper-locations: "classpath*:/mapper/**/*.xml" # Mapper.xml文件地址,当前这个是默认值。

5.条件构造器(了解)

6.Service的接口:

使用:在Service的接口中extends IService<实体类>,在ServiceImpl中使用implements Service

extends ServiceImpl<UserMapper,User>.

7.使用lambda,LambdaQuery<实体类>wrapper = new QueryWrapper<User>,可以去指定条件的

for example: .like(username !=null ,User::getUsername,username)

8.批量新增:

修改项目中的application.yml文件,在jdbc的url后面添加参数&rewriteBatchedStatements=true

速度有非常明显的提升,使用了jdbc的预编译模式。

9.代码生成

使用了MybatisPlus的插件

10.**静态工具的使用:**为了避免出现循环依赖问题,向IServiceImpl的使用(Db)

11.逻辑删除:

  • 在表中添加一个字段标记数据是否被删除

  • 当删除数据时把标记置为true

  • 查询时过滤掉标记为true的数据

XML 复制代码
mybatis-plus:
  global-config:
    db-config:
      logic-delete-field: deleted # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2)
      logic-delete-value: 1 # 逻辑已删除值(默认为 1)
      logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)

12.通用枚举

java 复制代码
package com.itheima.mp.enums;

import com.baomidou.mybatisplus.annotation.EnumValue;
import lombok.Getter;

@Getter
public enum UserStatus {
    NORMAL(1, "正常"),
    FREEZE(2, "冻结")
    ;
    private final int value;
    private final String desc;

    UserStatus(int value, String desc) {
        this.value = value;
        this.desc = desc;
    }
}

使用@EnumValue来去数据库的数据,@JsonValue来去注解标记JSON序列化时展示的字段

12.JSON 类型处理器

使用类处理器:@TableField(typeHandle = JcaksonTypeHandle.class),要去定义一个实体类,

来去处理json的数据。

相关推荐
老汉忒cpp7 分钟前
Redis string类型&&hash类型
java·redis·mybatis
终末圆23 分钟前
MyBatis—Plus 快速上手【后端 22】
java·开发语言·数据库·后端·sql·spring·mybatis
RainbowSea8 小时前
八,MyBatis-Plus 的“多数据源”的连接操作(详细说明)
java·spring·mybatis
爱上语文10 小时前
Springboot 练习
java·spring boot·后端·spring·mybatis
计算机学姐11 小时前
基于微信小程序的美食推荐系统
java·vue.js·spring boot·微信小程序·小程序·mybatis·美食
小小小小关同学11 小时前
【Redis】持久化机制--RDB和AOF
数据库·redis·mybatis
计算机学姐1 天前
基于SpringBoot+Vue的高校实习管理系统
java·vue.js·spring boot·后端·spring·intellij-idea·mybatis
爱跑步的程序员~1 天前
若依框架使用教程
vue.js·低代码·mybatis·springboot