首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

主键生成策略解读(@TableId)

基本介绍主键的作用是唯一标识,我们可以通过这个唯一标识来定位到这条数据。在数据库表数据中,主键生成可以遵循自定义的规则,但手动生成通常比较繁琐。...因此,在实际开发中,我们更倾向于使用框架提供的主键生成策略来自动生成主键。在MybatisPlus中,提供了@TableId注解来指定主键生成策略。这个注解允许我们为新增的数据指定主键生成方式。...该策略跟随数据库表的主键递增策略,前提是数据库表的主键要设置为自增。NONE:无状态,该类型为未设置主键类型(注解里等于跟随全局,全局里约等于INPUT)。INPUT:insert前自行set主键值。...) }ASSIGN_UUID策略示例ASSIGN_UUID策略使用UUID算法生成主键,适用于需要全局唯一字符串ID的场景。...自定义主键生成策略如果你需要实现自定义的主键生成策略,可以实现 com.baomidou.mybatisplus.extension.incrementer.IdentifierGenerator 接口

32721

mysql主键自增策略_MySQL 自增主键机制

自增主键:特指在自增列上定义的主键。 自增主键的优点是让主键索引保持递增顺序的插入,避免页分裂,索引更加紧凑。 1. 自增值保存在哪? 不同的存储引擎保存自增值的策略不一样; a....Innodb引擎,mysql5.7之前,自增值保存在内存中,而且不会持久化自增值。...自增值修改策略? a. 在插入时如不指定或指定为0,null,则使用当前的自增值填到自增字段;并设置当前自增值=当前自增值+auto_increment_increment 步长; b....为了减少自增id锁带来的性能影响,mysql不会修改回去之前的自增值; 4. 自增锁的优化 a....而对于批量插入数据的语句(select … insert,replace … select 和 load data 语句),MySQL 有一个批量申请自增 id 的策略(注:该策略是导致自增 id 不连续的第三种原因

9.4K50
您找到你想要的搜索结果了吗?
是的
没有找到

小书MybatisPlus第6篇-主键生成策略精讲

MybatisPlus第3篇-自定义SQL 小书MybatisPlus第4篇-表格分页与下拉分页查询 小书MybatisPlus第5篇-Active Record模式精讲 Mybatis Plus 为我们提供了三种设置 主键生成策略的方式...下面我们来一一介绍 一、默认主键生成策略:雪花算法 Mybatis Plus如果不做任何主键策略配置,默认使用的是雪花算法。...该策略会根据雪花算法生成主键ID,主键类型为Long或String(具体到MySQL数据库就是BIGINT和VARCHAR),该策略使用接口IdentifierGenerator的方法nextId(默认实现类为...二、自定义主键策略 mybatis-plus3.3.0以后,主要有五种主键生成策略。...public enum IdType { /** * 数据库ID自增,数据库需要支持主键自增(如MySQL),并设置主键自增 */ AUTO(0), /**

1.6K20

mybatisPlus主键策略解读

主键生成策略介绍 主键的作用就是唯一标识,我们可以通过这个唯一标识来定位到这条数据。当然对于表数据中的主键,我们可以自己设计生成规则,生成主键。...但是在更多的场景中,没有特殊要求的话,我们每次自己手动生成的比较麻烦,我们可以借助框架提供好的主键生成策略,来生成主键。...这样比较方便快捷 在MybatisPlus中提供了一个注解,是@TableId,该注解提供了各种的主键生成策略,我们可以通过使用该注解来对于新增的数据指定主键生成策略。...那么在以后新增数据的时候,数据就会按照我们指定的主键生成策略生成对应的主键。...,当我们没有指定主键生成策略或者主键策略为NONE的时候,他跟随的是全局策略,全局配置中 id-type是用于配置主键生成策略的,我们可以看一下id-type的默认值 通过查看源码发现,id-type

47910

(二)JPA 连接工厂、主键生成策略、DDL自动更新

entityManager.getTransaction().commit(); // 关闭连接 JPAEntityFactory.close(); } 3、主键生成...在JPA开发之中,主键数据的生成主要是基于@Id注解定义的,而在实际的项目开发之中,数据表的设计结构是有所不同的,所以JPA为了适应这些不同的数据表的定义,也提供有不同的主键生成策略。...JPA现在主要是基于 Hibernate 实现,那么 Hibernate 开发框架最早的一个特点就在于 可移植性,也就是说一个项目是在MySQL数据库下开发的,那么通过简单的配置修改,可以让代码直接在...DDL更新策略 3.1、使用 去到JPA配置文件中,修改DDL更新策略、 3.1.1、create 每次加载时,根据实体类生成表,如果表存在于数据库,会先删除 查看执行日志信:可以看到 drop

25710

基于Saas主键生成主键id

1.主键生成策略方式 ? 主键生成策略 2.基于Saas主键生成主键id流程 由于我们的系统时基于Saas的,因此生成主键时,需要以租户id(TenantId)为基础进行生成。...为了生成的id符合我们的租户的要求,通常都会现将租户表建好,然后基于租户表中的租户id进行主键id的生成。此时便产生基于租户id生成主键,那么怎样生成主键id呢?可以查看下图: ?...基于多租户生成方式 3.主键id生成实现的具体方式 首先需要对当前的id进行拦截操作,也即使用aop的切面Aspect对切点进行拦截,在进行新增的时候进行拦截: @Pointcut("execution...(* com.xtt..*.dao.mapper..*.insert*(..))") public void primaryKeyRule() {} 也就是说在进行主键生成时,我们拦截好需要生成主键...return current; } 从而实现主键自增的目的,从而实现基于租户id进行自增的策略

1.7K20

Mybatis-Plus3.0默认主键策略导致自动生成19位长度主键id的坑

底层ORM框架用的是Mybatis-Plus,我寻思了一下,这看起来像是在插入数据库旧自动生成的id,导致并非默认使用MySql的自增AUTO_INCREMENT的id。...19的数字当做该条数据的id插入到MySql,导致虽然MySql表设置了自增,但被该1468844351843872769影响了,导致下一条数据自动递增值变成了1468844351843872770,这种过长的...[image.png] 到这里,就确定,这个长数字的id,是在代码层次就自动生成了,最后进入对应的实体类中,发现该映射数据表的id字段,并没有显示设置对应的主键生成策略。...Model implements Serializable { private Long id; ...... } Mybatis-Plus主要有以下几种主键生成策略...这里的判断是否有@TableId 注解,就是判断是否需要取默认的主键策略,至于具体是如何设置默认主键的,我们可以直接进入到initTableIdWithoutAnnotation方法当中。

4.5K130

mysql 主键自增语句_MySQL 自增主键

MySQL 5.7 及之前的版本,自增主键最大值会在启动(重启)后从数据库中取出放到内存: SELECT MAX(ai_col) FROM table_name FOR UPDATE; 这样获取是通过计算的...从 MySQL 8.0 开始,自增主键最大值会在每次修改后写入到 redo log,并且在每个检查点写入引擎私有的系统表。 如果是正常重启,则读取系统表里的值。...(mutex) 三种插入定义: 简单插入 能够提前知道插入的行数 批量插入 不能提前知道插入的行数 混合插入 批量插入中的一部分的 ID 是指定的(非 0 且非 NULL),另一部分未指定,使用数据库生成的自增...其他 如果主动指定 ID 为 0 或者 NULL 插入,则会使用数据库生成的自增 ID。...参考文档 为什么 MySQL 的自增主键不单调也不连续 https://database.51cto.com/art/202004/614923.htm 《MySQL技术内幕——InnoDB存储引擎》

10.8K10

Mysql资料 主键

表中的任何列都可以作为主键,只要它满足以下条件: 1、任何两行都不具有相同的主键值 2、每个行都必须具有一个主键值(主键列不允许NULL值) 除MySQL强制实施的规则外,应该坚持的几个普遍认为的最好习惯为...: 1、不更新主键列的值 2、不重用主键列的值 3、不在主键列中使用可能会更改的值(例如,如果使用一个名字作为主键以标识某个供应商,应该供应商合并和更改其名字时,必须更改这个主键) 总之:不应该使用一个具有意义的...这就要求同一个叶子节点内(大小为一个内存页或磁盘页)的各条数据记录按主键顺序存放,因此每当有一条新的记录插入时,MySQL会根据其主键将其插入适当的节点和位置,如果页面达到装载因子(InnoDB默认为15...2、.如果使用非自增主键(如果身份证号或学号等),由于每次插入主键的值近似于随机,因此每次新纪录都要被插到现有索引页得中间某个位置: 此时MySQL不得不为了将新记录插到合适位置而移动数据,甚至目标页面可能已经被回写到磁盘上而从缓存中清掉...如果没有显式地在表定义时指定主键,InnoDB存储引擎会为每一行生成一个6字节的ROWID,并一次作为主键mysql 在频繁的更新、删除操作,会产生碎片。而含碎片比较大的表,查询效率会降低。

3.7K20

MySQL主键

本文标识 : MQ0021 本文编辑 : 长安月下赏美人儿 编程工具 : MySQL、DBeaver 阅读时长 : 4分钟 前言 小编在查询相关的学习资料的同时,偶尔会遇到关于主键的信息,也是一直没有很清晰的认知...定义:PRIMARY KEY 注意:主键之于数据表相当于口红之于女人,可以不用,但最好还是有 主键选择的遵循原则 任何两行都不具有相同的主键值 每行必须具有一个主键值,且不允许设置为NULL 主键应当是对用户没有意义的...永远不要更新主键主键除了唯一标识一行之外再无其他意义 主键不应包含动态变化的数据,如时间戳、创建/修改时间列等 主键应当由计算机自动生成 主键的作用 保证实体的完整性 加快数据库的操作速度 在表中添加新记录时...,DBMS会自动检查新记录的主键值,不允许该值与其他记录的主键值重复 DBMS自动按主键值的顺序显示表中的记录 如果没有定义主键,则按输入记录的顺序显示表中的记录 主键的选择 编号为主键 方法:选择唯一字段...设置主键的方法 在创建数据表的同时决定是否有主键 #带主键 CREATE TABLE test1( id INT NOT NULL PRIMARY KEY, name CHAR(20) ); #带复合主键

3.7K10

浅谈数据库主键策略

浅谈数据库主键策略 数据库表的主键很多童鞋都非常熟悉了,主键就是Primary Key,简称PK。...主键不可修改 对于数据库来说,主键其实是可以修改的,只要不和其他主键冲突就可以。但是,对于应用来说,如果一条记录要修改主键,那就会出大问题。...使用整数有两个选择:数据库自增和自己生成。 自己生成其实也是自增,无非就是把上次使用的值保存到某个地方,下次使用的时候继续自增。常见的做法是用一个单独的表存储上次用的最大值。...方法一,直接用时间戳+UUID构造一个主键,时间戳注意补0,这样生成主键就是按时间排序的。这个方法简单粗暴,缺点是主键更长了。...但是剩下的位不是ffffffff而是只有fffff,如果给机器分配ff作为标识,那么每秒只能最多生成0xfff+1=4096个主键,对一些大型应用不太够用。

1.4K100

MySQL主键详解

表中的任何列都可以作为主键,只要它满足以下主键值规则条件: 任两行不具相同的主键值 每行都必须具有一个主键值(主键列不允许NULL) 这里的规则是MySQL本身强制实施的。...除MySQL强制实施的规则外,还应该坚持的最佳实践: 不更新主键列中的值 不重用主键列的值 不在主键列中使用可能会更改的值 例如,如果使用一个名字作为主键以标识某个供应商,当该供应商合并和更改其 名字时...,必须更改这个主键) 联合主键 好处 可以直观的看到某个重复字段的记录条数 主键A跟主键B组成联合主键 主键A跟主键B的数据可以完全相同,联合就在于主键A跟主键B形成的联合主键是唯一的。...联合主键体现在多个表上,复合主键体现在一个表中的多个字段。 复合主键 主键通常定义在表的一列上,但这并不是必需的,也可使用多个列作为主键。...不与业务耦合,因此更容易维护 通用的键策略能够减少要编写的源码数量,减少系统的总体拥有成本 自然主键 事物属性中的自然唯一标识

4.9K20

MySQL主键设计盘点

最近在项目中用了UUID的方式生成主键,一开始只是想把这种UUID的方式生成主键记录下来,在查阅资料的过程中,又有了一些新的认识和思考。 主键定义 唯一标识表中每行的一个列(或一组列)称为主键。...主键设计和应用原则 除了满足MySQL强制实施的规则(主键不可重复;一行中主键不可为空)之外,主键的设计和应用应当还遵守以下公认的原则: 不更新主键列中的值; 不重用主键列的值; 不在主键列中使用可能会更改的值...主键生成策略 自增ID 使用数据库的自动增长(auto_increment),是比较简单和常见的ID生成方案,数据库内部可以确保生成id的唯一性。...结论: 用自建的id生成器做主键适用于大规模分布式架构 参考: 【1】:红心李 :MySQL主键设计 【2】:Uncle Nucky :MySQL数据库主键设计原则 【3】:ellis:设计套路:Mysql...主键的选取 【4】:路人甲Java:分布式系统生成唯一id常见方案 【5】:《MySQL必知必会》 【6】:美团技术团队:Leaf——美团点评分布式ID生成系统 【7】:UUID performance

4.2K30
领券