在if(isFill)方法当中,最重要的是populateKeys(metaObjectHandler, tableInfo, ms, parameterObject, isInsert);这个方法,这个方法就是根据不同的id策略,去生成不同的id值,然后填充到id字段里,最终插入到数据库当中。而我们要找的最终方法,正是在这里面—— protectedstaticObjectpopulateKeys(MetaObjectHandlermetaObject...
了解MyBatis-Plus的Insert操作: MyBatis-Plus提供了一系列简化CRUD操作的方法,其中insert方法用于向数据库中插入一条新记录。 当数据库表的主键设置为自增时,MyBatis-Plus在执行插入操作后会自动将生成的自增ID填充到实体类的主键属性中。 研究如何在MyBatis-Plus中获取插入操作后的自增ID: 如果使用了MyBatis-Plus...
DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mappernamespace="com.virtuous.demo.mapper.MyTestMapper"><insertid="insertUser"useGeneratedKeys="true"keyProperty="id">INSERT INTO my_test (name) VALUES (#{po.name})</insert></...
ID_WORKER_STR(5): 表示字符串形式的全局唯一ID,这是idWorker生成的ID的字符串表示形式,便于在需要字符串ID的场景下使用。 接下来,让我们跟着源码看一下,究竟是如何基于这些ID策略做id自增的,本文主要以ID_WORKER(3)策略id来追踪。 先从插入insert方法开始。 基于前文创建的UserInfo类,我们写一个test的方法,用...
底层ORM框架用的是Mybatis-Plus,我寻思了一下,这看起来像是在插入数据库旧自动生成的id,导致并非默认使用MySql的自增AUTO_INCREMENT的id。 因此,决定一步步定位,先给Mybatis-Plus打印出sql日志,看下其insert语句是否自动生成了一个id,然后才插入数据库。
带着这样的疑惑,我开始研究了一番Mybatis Plus的insert自增id的策略源码,并将其写成了本文。 先来看一下Mybatis Plus生成id的自增策略,可以通过枚举IdType设置以下数种策略—— @Getter public enum IdType { /** * 数据库ID自增 */ AUTO(0), ...
底层ORM框架用的是Mybatis-Plus,我寻思了一下,这看起来像是在插入数据库就自动生成的id,导致并非默认使用MySql的自增AUTO_INCREMENT来生成id。 因此,决定一步步定位,先给Mybatis-Plus打印出sql日志,看下其insert语句是否自动生成了一个id后才插入数据库。
mybatis-plus 执行insert(),实体的id自动更新 mybatis-plus 在执行baseMapper.insert()的时候,会将传进去的实体的id自动更新为插入的主键值。 业务代码 @Transactional(rollbackFor = Exception.class)@OverridepublicStringsaveCourseInfo(CourseInfoForm courseInfoForm){//保存课程基本信息Coursecourse=newCourse(); ...
@TableId(type = IdType.ID_WORKER) private Long id; private String name; private Integer age; private String email; @TableField(fill = FieldFill.INSERT) // 新增的时候填充数据 private Date createTime; @TableField(fill = FieldFill.INSERT_UPDATE) // 新增或修改的时候填充数据 ...