1. 确保数据库表设置了自增ID 首先,你需要确保你的数据库表的主键列被设置为自增(AUTO_INCREMENT,对于MySQL而言)。这是数据库层面的配置,确保每次插入新记录时,主键列会自动生成一个新的唯一值。 2. 调用MyBatis-Plus的插入方法 在MyBatis-Plus中,你可以通过Mapper接口的insert方法来插入数据。当插入成功后,MyB...
在if(isFill)方法当中,最重要的是populateKeys(metaObjectHandler, tableInfo, ms, parameterObject, isInsert);这个方法,这个方法就是根据不同的id策略,去生成不同的id值,然后填充到id字段里,最终插入到数据库当中。而我们要找的最终方法,正是在这里面—— protectedstaticObjectpopulateKeys(MetaObjectHandlermetaObject...
ID_WORKER_STR(5): 表示字符串形式的全局唯一ID,这是idWorker生成的ID的字符串表示形式,便于在需要字符串ID的场景下使用。 接下来,让我们跟着源码看一下,究竟是如何基于这些ID策略做id自增的,本文主要以ID_WORKER(3)策略id来追踪。 先从插入insert方法开始。 基于前文创建的UserInfo类,我们写一个test的方法,用...
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></...
带着这样的疑惑,我开始研究了一番Mybatis Plus的insert自增id的策略源码,并将其写成了本文。 先来看一下Mybatis Plus生成id的自增策略,可以通过枚举IdType设置以下数种策略—— 代码语言:javascript 复制 @GetterpublicenumIdType{/** * 数据库ID自增 ...
底层ORM框架用的是Mybatis-Plus,我寻思了一下,这看起来像是在插入数据库旧自动生成的id,导致并非默认使用MySql的自增AUTO_INCREMENT的id。 因此,决定一步步定位,先给Mybatis-Plus打印出sql日志,看下其insert语句是否自动生成了一个id,然后才插入数据库。
底层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(); ...
在实体类自增的id字段添加一个注解 mybatis plus在插入记录时,有以下几种方法: booleaninsert(T var1);booleaninsertAllColumn(T var1);booleaninsertBatch(List var1);booleaninsertBatch(List var1,intvar2);booleaninsertOrUpdateBatch(List var1);booleaninsertOrUpdateBatch(List var1,intvar2); ...