mybatis plus实体类主键策略有3种

mybatis plus 实体类主键策略有3种( 注解 > 全局 > 默认 )

  1. 注解方式

    @TableId(type = IdType.AUTO)在实体类增加注解即可

@TableName("t_article")
public class TArticle extends Model<TArticle> {
    private static final long serialVersionUID = 1L;
    /**
     * id
     */
    @TableId(type = IdType.AUTO)
    private Long id;
    /**
     * 正文
     */
    private String article;
    }
  1. 全局
    生成数字型ID:895503808246718464,ID长度超出JavaScript
  2. 默认,mybatis plus默认使用全局唯一的数字类型
    ID_WORKER(2, “全局唯一ID”),生成的ID格式:ccba0a05fcbe46898304d5213d2b5518
class TableInfoHelper
private static boolean initTableId(GlobalConfiguration globalConfig, TableInfo tableInfo, Field field,
            Class<?> clazz) {
        TableId tableId = field.getAnnotation(TableId.class);
        if (tableId != null) {
            if (tableInfo.getKeyColumn() == null) {
                /*
                 * 主键策略( 注解 > 全局 > 默认 )
                 */
                if (IdType.INPUT != tableId.type()) {
                    tableInfo.setIdType(tableId.type());
                } else {
                    tableInfo.setIdType(globalConfig.getIdType());
                }
                /* 字段 */
                String column = field.getName();
                if (StringUtils.isNotEmpty(tableId.value())) {
                    column = tableId.value();
                    tableInfo.setKeyRelated(true);
                } else {
                    // 开启字段下划线申明
                    if (globalConfig.isDbColumnUnderline()) {
                        column = StringUtils.camelToUnderline(column);
                    }
                    // 全局大写命名
                    if (globalConfig.isCapitalMode()) {
                        column = column.toUpperCase();
                    }
                }
                tableInfo.setKeyColumn(column);
                tableInfo.setKeyProperty(field.getName());
                return true;
            } else {
                throwExceptionId(clazz);
            }
        }
        return false;
    }
### MyBatis 中配置实体类主键自增的方法 在 MyBatisMyBatis-Plus 的开发场景下,可以通过多种方式实现主键自增的功能。以下是几种常见的方法及其具体实现。 #### 方法一:通过 MyBatis-Plus 配置全局主键策略 MyBatis-Plus 提供了一种便捷的方式用于定义主键生成策略。可以在 `application.yml` 文件中指定全局的主键生成模式为自动增长: ```yaml mybatis-plus: global-config: db-config: id-type: auto ``` 上述配置表示数据库表的主键由数据库本身负责分配并自增[^1]。需要注意的是,这种方式依赖于底层数据库的支持(如 MySQL 的 AUTO_INCREMENT 属性)。因此,在创建数据表时需确保主键字段已启用该属性。 #### 方法二:解决 XML 插入语句中的主键冲突问题 当手动编写 Insert SQL 并未正确处理主键赋值逻辑时,可能会引发重复插入错误。例如,如果直接将 `id` 字段作为参数传入而未让其参与自增,则可能出现如下异常情况: > Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLIntegrityConstraintViolationException: Duplicate entry &#39;0&#39; for key &#39;PRIMARY&#39; 这是因为每次插入操作都将默认值设为了零所致[^2]。为了避免此类现象发生,可以移除映射文件内的 `<insert>` 节点里有关 ID 参数的部分声明或者调整为允许 DB 自动生成的形式。 #### 方法三:利用 SelectKey 获取最后插入记录的主键值 对于某些特殊需求场合可能并不希望完全交予 RDBMS 控制整个流程而是想获得新产生的 KEY 后再做进一步动作的话,则可通过 `<selectKey>` 标签来完成此目的: ```xml <insert id="insertUser"> <selectKey keyProperty="userId" resultType="java.lang.Integer" order="AFTER"> SELECT LAST_INSERT_ID() </selectKey> insert into users(user_name) values(#{userName}) </insert> ``` 这里的关键在于设置了 `order="AFTER"` 表明只有在真正完成了 INSERT 动作之后才会去查询最新的那个编号填充回对象实例之中;另外还指定了返回的数据类型以及目标变量名以便后续访问使用[^3]. #### 方法四:借助 Mapper 接口定义保存行为 除了以上提到的技术手段外还可以考虑直接修改 DAO Layer 上面所提供的 API 定义形式从而间接影响到底层是如何运作的。比如下面这个例子展示了怎样设计一个能够接受列表批量新增请求的同时又能保证每条记录都拥有独一无二的身份标识符的能力: ```java public interface QuestionMapper { int saveQuestionAnswer(@Param("questionId") Long questionId, @Param("list") List<XzsQuestionsAnswerCreate> list); } ``` 此时只要保证所关联的那个表结构已经开启了相应的特性支持即可无需额外操心太多细节部分[^4]. --- ### 注意事项 无论采用哪种方案都需要确认当前使用的数据库引擎确实具备相应功能并且版本号满足最低要求限制条件才行哦!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值