mybatis-plus使用总结

本文介绍MyBatis Plus的基本配置方法,包括表名与实体类映射、字段匹配、驼峰命名转换开关、表前缀配置、SQL日志输出等。同时探讨了如何利用注解实现插入和更新时间的自动填充,并介绍了几种主键生成策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.默认使用驼峰转换,如果实体类名称或者字段是驼峰格式,转化成的对应数据库表名或者字段就是下划线分割的,如isDelete 对应的就是is_delete

2.如果表名与实体类名称不对应则实体类用@TableName(“t_user”)映射表名,@TableField可解决字段与数据库表字段不对应的问题;

3.关闭驼峰可在配置文件中配置

mybatis-plus:
  configuration:
    map-underscore-to-camel-case: false

注意mybatis-plus与spring并列级别

4.可在配置文件中配置表前缀

mybatis-plus:
  global-config:
    db-config:

5.查看控制台sql日志输出:

mybatis-plus:

    configuration:

         log-impl: org.apache.ibatis.logging.stdout.StdOutImpl

6. insertFill拦截保存时的数据,不过需要在实体类中createdTime,updatedTime上加上下面注解

@TableField(fill = FieldFill.INSERT)

updateFill拦截更新数据,不过需要在实体类中updatedTime加上下面注解

@TableField(fill = FieldFill.INSERT_UPDATE)

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
    @Override
    public void insertFill(MetaObject metaObject) {
        this.setFieldValByName("createdTime", LocalDateTime.now(), metaObject);
        this.setFieldValByName("updatedTime", LocalDateTime.now(), metaObject);
    }

    @Override
    public void updateFill(MetaObject metaObject) {
        this.setFieldValByName("updateTime", LocalDateTime.now(), metaObject);
    }

}

7.实体类主键设置

@TableId(value = "user_id",type = IdType.AUTO)  主键自增

@TableId(type = IdType.ASSIGN_UUID)  自动生成不含中划线的 UUID 作为主键。主键类型为 String

@TableId(type = IdType.ASSIGN_ID)  该策略会使用雪花算法自动生成主键 ID,主键类型为 Long 或 String

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值