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

mysql建表主键自增长

基础概念

MySQL中的主键(Primary Key)是表中的一个或多个字段,用于唯一标识表中的每一行记录。主键具有以下特性:

  • 唯一性:主键的值必须是唯一的,不能有重复。
  • 非空性:主键的值不能为空。
  • 一个表只能有一个主键。

自增长(AUTO_INCREMENT)是MySQL提供的一种特性,用于自动为表中的主键字段生成唯一的递增值。通常用于整数类型的主键字段。

相关优势

  1. 简化插入操作:自增长主键可以自动为新插入的记录生成唯一标识,无需手动指定主键值。
  2. 保证唯一性:自增长主键确保每一行记录都有一个唯一的标识符。
  3. 提高查询效率:主键通常是索引的一部分,使用自增长主键可以提高查询效率。

类型

MySQL中的自增长主键通常是整数类型,如INTBIGINT等。

应用场景

自增长主键广泛应用于各种数据库表中,特别是在需要唯一标识每一行记录的场景中,例如:

  • 用户表:每个用户有一个唯一的用户ID。
  • 订单表:每个订单有一个唯一的订单ID。
  • 商品表:每个商品有一个唯一的商品ID。

示例代码

以下是一个创建带有自增长主键的MySQL表的示例:

代码语言:txt
复制
CREATE TABLE users (
    id INT AUTO_INCREMENT PRIMARY KEY,
    username VARCHAR(50) NOT NULL,
    email VARCHAR(100) NOT NULL UNIQUE
);

在这个示例中,id字段被定义为主键,并且使用AUTO_INCREMENT特性使其自增长。

可能遇到的问题及解决方法

问题1:自增长主键值不连续

原因:删除记录后,自增长主键的值不会回退,而是继续递增。

解决方法

  • 通常不需要特别处理,因为自增长主键的目的是唯一标识记录,而不是连续的数字。
  • 如果确实需要连续的主键值,可以考虑使用其他方法生成唯一标识符,如UUID。

问题2:自增长主键达到上限

原因:如果使用INT类型作为自增长主键,当插入的记录数超过INT类型的最大值(2^31-1)时,将无法继续插入新记录。

解决方法

  • 使用更大的整数类型,如BIGINT,其最大值为2^63-1,可以支持更多的记录。
  • 重新设置自增长主键的起始值和步长,但这通常不推荐,因为可能会导致主键值的重复。

参考链接

通过以上信息,您应该对MySQL中自增长主键的概念、优势、类型、应用场景以及常见问题有了全面的了解。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

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

MySQL 5.7 及之前的版本,自增主键最大值会在启动(重启)后从数据库中取出放到内存: SELECT MAX(ai_col) FROM table_name FOR UPDATE; 这样获取是通过计算的...从 MySQL 8.0 开始,自增主键最大值会在每次修改后写入到 redo log,并且在每个检查点写入引擎私有的系统表。 如果是正常重启,则读取系统表里的值。...注:如果 redo log 都没刷入,就更不用说将数据插入数据表了。 自增主键插入时的连续性 这里不考虑由于删除导致的连续性问题 为何会有连续性问题? 这主要是跟插入事务回滚有关系。...之所以事务 A 没提交的情况下,事务 B 就能执行插入语句,跟 InnoDB 的自增长锁(AUTO-INC Locking)相关。...参考文档 为什么 MySQL 的自增主键不单调也不连续 https://database.51cto.com/art/202004/614923.htm 《MySQL技术内幕——InnoDB存储引擎》

10.8K10
  • mysql主键自增策略_MySQL 自增主键机制

    自增主键:特指在自增列上定义的主键。 自增主键的优点是让主键索引保持递增顺序的插入,避免页分裂,索引更加紧凑。 1. 自增值保存在哪? 不同的存储引擎保存自增值的策略不一样; a....对于MyISAM引擎,自增值保存在数据文件中; b. Innodb引擎,mysql5.7之前,自增值保存在内存中,而且不会持久化自增值。...每次重启后第一次打开表,都会去查找自增值的最大值max(id), 并设置表当前自增值为max(id) + 1; mysql8.0, 自增值变更记录在了redo log中,重启时依靠redo log恢复重启之前的值...自增值修改发生在插入数据的操作之前,如果插入失败,自增值不会再修改回去; b. 事务回滚也不会将自增值修改回去; c. 为了减少自增id锁带来的性能影响,mysql不会修改回去之前的自增值; 4....而对于批量插入数据的语句(select … insert,replace … select 和 load data 语句),MySQL 有一个批量申请自增 id 的策略(注:该策略是导致自增 id 不连续的第三种原因

    9.5K50

    oracle建表、建主键、外键基本语法

    主键:唯一标识,不能为空,加快查询速度,自动创建索引 外键:约束内表的数据的更新,从定义外键时可以发现 外键是和主键表联系,数据类型要统一,长度(存储大小)要统一。...这样在更新数据的时候会保持一致性 -创建表格语法: create table 表名( 字段名1 字段类型(长度) 是否为空, 字段名2 字段类型 是否为空...); -增加主键 alter table 表名 add constraint 主键名 primary key (字段名1); -增加外键: alter table 表名...add constraint 外键名 foreign key (字段名1) references 关联表 (字段名2); 在建立表格时就指定主键和外键 create table...varchar2(8) not null, constraint PK_T_STU primary key (STU_ID) ); 主键和外键一起建立

    3.1K50

    Oracle实现主键自增长的几种方式

    使用SQLServer、MySQL时,无论我们使用的是直接JDBC连接数据库,还是通过Hibernate操纵数据库,我们只需要设置一个选项或者一行注解便可以实现主键的自增长。...但Oracle没有直接提供主键自增长的功能,这里我们可以使用两种方式来解决主键自增长的问题。 第一种,通过序列以及触发器实现主键自增长。 这种方式适用于直接使用JDBC连接数据库。...这种方式将主键自增长的任务完全交给数据库,我们无需在代码层面上进行任何控制。 第二种,通过序列以及Hibernate配置实现自增长。 这种方式适用于通过Hibernate连接数据库的方式。...这两种方式都是通过Oracle的序列实现自增长,但第一种通过数据库的触发器在插入的时候自动插入主键。而后者则由Hibernate自动完成获取主键,插入主键这一操作。...一、通过序列以及触发器实现主键自增长 首先,为每个表创建一个序列: 1 /* 创建序列 */ 2 --为bitinfo表的主键创建序列 3 create sequence bitinfo_id_seq

    1.7K20

    mysql自增主键设置

    mysql自增主键设置 在数据库应用中,经常希望在每次插入新纪录时,系统自动生成字段的主键值。可以通过为表主键添加AUTO_INCREMENT关键字来实现。...默认情况下,在MYSQL中AUTO_INCREMENT的初始值是1,每新增一条记录,字段值自动加1.一个表只能有一个字段属用AUTO_INCREMENT约束,且该字段必须为主键的一部分。...AUTO_INCREMENT约束的字段可以是任何整数类型(TINTINT、SMALLINT、INT、BIGINT等) 设置表的属性值自动增加的语法规则如下: 字段名 数据类型 AUTO_INCREMENT...创建表,指定编号自动递增 create table tb_emp8( id int(11) PRIMARY KEY auto_increment, name VARCHAR(25) not null...FLOAT ); 执行插入语句: insert into tb_emp8(name,salary) values('lucy',1000),('lura',1200),('kevin',1500); 查看数据表

    11.1K30

    MySQL 约束与自增长

    # MySQL 约束与自增长 mysql约束 基本介绍 primary key(主键)-基本使用 not null和unique(唯一) foreign key(外键) check 商店售货系统表设计案例...自增长 自增长基本介绍 自增长使用细节 # mysql约束 # 基本介绍 约束用于确保数据库的数据满足特定的商业规则。...一张表最多只能有一个主键,但可以是复合主键主键的指定方式有两种 直接在字段名后指定:字段名primakry key在表定义最后写primary key(列名); 使用desc表名,可以看到primary...# 自增长基本介绍 # 自增长使用细节 一般来说自增长是和primary key配合使用的 自增长也可以单独使用[但是需要配合一个unique] 自增长修饰的字段为整数型的(虽然小数也可以但是非常非常少这样使用...) 自增长默认从1开始,你也可以通过如下命令修改altertable表名auto increment=新的开始值; 如果你添加数据时,给自增长字段(列)指定的有值,则以指定的值为准,如果指定了自增长,一般来说

    3.1K30

    MyCat教程【全局序列号-全局主键自增长】

    ,那么这就涉及到了主键维护的问题,此时肯定不能使用单个数据库中id自增的方式来处理了,这时我们就可以通过MyCat中提供的几种增长的方式来实现 全局主键自增 一、本地文件自增方式   首先我们来看下第一种方式...修改分片策略   我们原来配置的分片策略crc32slot是不支持主键自增的,所以我们需要修改为auto-sharding-long ? 2....修改server.xml文件   server.xml文件中的sequnceHandlerType是用来配置主键生成类型的 sequnceHandlerType值 说明 0 本地文件自增方式 1 数据库自增方式...生成成功~ 三、数据库自增方式 1.创建序列表和相关函数   第三种方式是在Mycat所管理的某个数据库中创建一张自增的表结构来维护相关的数据,相关的脚本官方提供的有,如下: DROP TABLE IF...主键的生成成功,除了这三种方式以外还可以通过`zookeeper`来维护自增的主键,这个可以自行实现

    1.6K20

    MySql中InnoDB表为什么要建议用自增列做主键

    这就要求同一个叶子节点内(大小为一个内存页或磁盘页)的各条数据记录按主键顺序存放,因此每当有一条新的记录插入时,MySQL会根据其主键将其插入适当的节点和位置,如果页面达到装载因子(InnoDB默认为15.../16),则开辟一个新的页(节点) 4、自增主键 如果表使用自增主键,那么每次插入新的记录,记录就会顺序添加到当前索引节点的后续位置,当一页写满,就会自动开辟一个新的页 5、非自增主键 如果使用非自增主键...总结 如果InnoDB表的数据写入顺序能和B+树索引的叶子节点顺序一致的话,这时候存取效率是最高的,也就是下面这几种情况的存取效率最高: 1、使用自增列(INT/BIGINT类型)做主键,这时候写入顺序是自增的...,和B+数叶子节点分裂顺序一致; 2、该表不指定自增列做主键,同时也没有可以被选为主键的唯一索引(上面的条件),这时候InnoDB会选择内置的ROWID作为主键,写入顺序和ROWID增长顺序一致; 除此以外...《高性能MySQL》中的原话 ? ?

    3.9K20

    MySQL自增主键详解「建议收藏」

    (初始值)开始,以auto_increment_increment(步长)为步长,持续叠加,直到找到第一个大于X的值,作为新的自增值 三、自增值的修改时机 创建一个表t,其中id是自增主键字段、c是唯一索引...,建表语句如下: CREATE TABLE `t` ( `id` int(11) NOT NULL AUTO_INCREMENT, `c` int(11) DEFAULT NULL, `d`...出现了自增主键不连续的情况 唯一键冲突和事务回滚都会导致自增主键id不连续的情况 四、自增锁的优化 自增id锁并不是一个事务锁,而是每次申请完就马上释放,以便允许别的事务再申请 但在MySQL5.0版本的时候...也就是说,如果一个语句申请了一个表自增锁,这个锁会等语句执行结束以后才释放 MySQL5.1.22版本引入了一个新策略,新增参数innodb_autoinc_lock_mode,默认值是1 1.这个参数设置为...之后,再执行insert into t2 values(null, 5,5),实际上插入了的数据就是(8,5,5) 这是主键id出现自增id不连续的第三种原因 五、自增主键用完了 自增主键字段在达到定义类型上限后

    5.9K40

    MySQL 主键自增注意事项

    很多小伙伴应该知道,在 MySQL 中主键不应该使用随机字符串。但是主键不用随机字符串用什么?主键自增?主键自增就是最佳方案吗?有没有其他坑?今天我们就来讨论下这个话题。 1....为什么不用 UUID 经过上篇文章的介绍,我们知道在 MySQL 中,主键索引就是聚簇索引,MySQL 表中的数据是根据主键值聚集在一起的,聚簇索引是一棵 B+Tree,这棵树中的数据是有序的。...基于上面的分析,我们在 MySQL 中尽量不使用 UUID 作为主键,不用 UUID,可能会有小伙伴想到,那我使用主键自增行不行?...主键自增有没有一些需要注意的问题? 2. 主键自增的问题 以下内容,有一个共同的大前提,就是我们的表设置了主键自增。 一般来说,主键自增是没有什么问题的。但是,如果在高并发环境下,就会有问题了。...SQL 语句开始的时候,获取到一个表级的 AUTO-INC 锁,然后当插入 SQL 执行完毕之后,再释放掉这把锁,这样做的好处是可以确保在批量插入的时候,自增主键是连续的。

    13410

    MySQL自增主键值回溯问题

    平时我们使用MySQL时,通常每一个表都会有一个自增主键ID,每新增一条数据,ID值就会自增1。但在8.0之前版本的MySQL中,这个自增值会存在一个回溯的问题。...例如,在一个新表中插入三条主键为1、2、3的数据行,这时候用SHOW CREATE TABLE命令查看该表的AUTO_INCREMENT的值是4,这是没问题的。...但如果重启一下MySQL,这个值就会变回3,而不是4,发生了回溯。...这是因为AUTO_INCREMENT的值只存储于内存中,不会持久化到磁盘,每次启动数据库时,MySQL会通过计算max(auto_increment字段) + 1,重新作为该表下一次的主键ID的自增值。...这个问题直至MySQL 8.0才修复。 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/149188.html原文链接:https://javaforall.cn

    4.2K20

    领导大怒:建表不加主键的都是耍流氓

    MySQL在创建表时,如果你没有显示的创建主键,那么innodb会自动帮你创建一个不可见的、长度是6字节的row_id,所有未定义主键的表共享该row_id,每次插入一条数据row_id加1。...在创建表时,DBA一般都会建议一定要在这个表上显示的定义一个主键,那么如果没有创建主键会有哪些影响呢,今天我们就来说一下主键在主从复制中的影响以及如何选择主键。...> update t set name='主键测试,结果验证' where id <10000; 从库检查延迟情况 mysql> show slave status\G ****************...单机模式下可以采用自增ID作为主键的方案,该方案的优点是顺序存放,插入速度快,数字类型,占用空间小,易排序,但是该方案也有缺点,不支持分布式架构,在分布式数据库架构中不能保证主键的全局唯一。...在分布式数据库中可以采用自增ID作为物理主键,UUID作为逻辑主键的方案,或者自定义实现主键值的获取,来保证分库分表后的全局唯一性,比如淘宝的分布式数据库中间件TDDL提供的Sequence解决方案等。

    2K20

    MySQL列属性之自增长

    自增长通常是跟主键搭配。 新增自增长 任何一个字段要做自增长必须前提是本身是一个索引(key一栏有值)。 自增长字段必须是数字(整型) 一张表最多只能有一个自增长,和主键一起搭配。...如上图运行结果可知: 1.自增长起始为1,且每次加1。 2.自增长如果对应的字段输入了值,那么自增长失效,但是下一次还是能够正确的自增长,即值加1。...修改自增长 自增长如果是涉及到字段改变,则必须先删除自增长,后增加,因为一张表有且只能有一个自增长。 修改当前自增长已经存在的值:修改只能比当前已有的自增长的最大值大,不能小,否则不会生效。...语句形式:alter table 表名 auto_increment = 值; 示例: -- 修改表选项的值 alter table my_auto auto_increment =4; -- 向下修改...可以修改变量实现不同的效果:修改是针对整个数据修改,而不是单张表(修改是会话级) 语句形式:set auto_increment_increment=5; — 一次修改5 删除自增长 自增长是字段的一个属性

    4.7K20

    MySQL自增主键为什么不连续

    自增主键可以让主键索引尽量的保持递增顺序插入,避免页分裂,索引更加紧凑。 自增主键保存在何处?...不同的引擎对于自增值的保存策略不同: MyISAM引擎的自增值保存在数据文件中 InnoDB引擎的自增值保存在内存里,但是在MySQL8.0以后,该自增值才可以被持久化:MySQL5.7以前,自增值没有持久化每次重启后第一次打开表的时候...,会找自增值的最大值max(id),然后将最大值加1作为这个表的自增值;MySQL8.0版本会将自增值的变更记录在redo log中,重启时依靠redo log恢复。...values(null, 1, 1); 执行器调用InnoDB引擎写入一行,传入的这一行的值是(0,1,1) InnoDB发现用户没有指定id,获取表t当前的自增值2 将传入的行改为(2,1,1) 将表的自增值改为...t\G 可以看到自增主键已经从3变成4,但是并没有因为事务的回滚回退。

    8.4K20

    mysql为什么建议使用自增主键

    我们都知道表的主键一般都要使用自增 id,不建议使用业务 id ,是因为使用自增 id 可以避免页分裂。这个其实可以相当于一个结论,你都可以直接记住这个结论就可以了。...我这里也稍微解释一下页分裂,mysql (注意本文讲的 mysql 默认为InnoDB 引擎)底层数据结构是 B+ 树,所谓的索引其实就是一颗 B+ 树,一个表有多少个索引就会有多少颗 B+ 树,mysql...如果主键为自增 id 的话,mysql 在写满一个数据页的时候,直接申请另一个新数据页接着写就可以了。...如果主键是非自增 id,为了确保索引有序,mysql 就需要将每次插入的数据都放到合适的位置上。...本来这篇文章是打算总结一下前面写的几篇关于 mysql 索引的文章的,也是打算多举几个例子的,结果发现光写了一个自增主键就写了一大堆了,然后时间也比较晚了,干脆就写到这吧,原本计划的几个其他例子后面再单独写吧

    5K31

    MySQL主键自增值为什么有“空洞”?

    最终发现了MySQL主键自增值“空洞”了 1.场景准备 测试场景为MySQL 8.0: 主键重复场景 唯一键重复场景 1、建表,包含主键及唯一约束 CREATE TABLE t1( id int(...# 测试主键重复 mysql> replace into t1 values (1,'aaa', 111); Query OK, 2 rows affected (0.00 sec) mysql> select...在此前,现在该表的自增值是7,重启后又变成4了。...,但如果往小的修改就要看目前数据库插入的值是否会将修改后的自增值“卡”在中间,如果出现这种情况是没办法改回去的,原因显而易见,自增属性与主键配套使用,如果现在表里id=4和id=6之间差了个5的值,将自增值改回...技术分享 | 微服务架构的数据库为什么喜欢分库分表?

    2.3K20
    领券