关于mysql的int型主键自增问题

引入

我们在使用mysql数据库时,习惯使用int型作为主键,并设置为自增,这既能够保证唯一,使用起来又很方便,但int型的长度是有限的,如果超过长度怎么办呢?

暴露问题

我们先创建一个测试表,创建语句如下:

CREATE TABLE test1 (
  id INT PRIMARY KEY AUTO_INCREMENT,
  NAME VARCHAR(20)
)

然后我们插入两条数据:

INSERT INTO test1 VALUES(NULL,'小牛');
INSERT INTO test1 VALUES(NULL,'大牛');

查询表显示正常:
在这里插入图片描述int型的有符号的范围为231 -1 = 2147483647,我们直接插入一条数据id为2147483647,如下:

INSERT INTO test1 VALUES(2147483647 ,'小华')

结果显示正常:
在这里插入图片描述
此时自增ID已达到了int型的上限,如果我再插入数据,就会报错:

INSERT INTO test1 VALUES(NULL,'母牛');

在这里插入图片描述
此时主键已无法自增,插入的id仍然是2147483647,就违反了主键唯一的条件,所以报错。

解决问题

(1)使用更大的数据类型bigint

bigint的范围是263-1,所谓指数爆炸,此时的大小达到了9,223,372,036,854,775,807的可怕量级,简单来说就是用bigint 一天100w条数据也得存200亿年才能自增爆炸,所以在当前场景,几乎不用担心bigint会自增满

我们修改数据类型为bigint,如图
在这里插入图片描述
再执行插入语句:

INSERT INTO test1 VALUES(NULL,'母牛');

又能够正常插入了:
在这里插入图片描述

(2)使用UUID作为主键

我们都知道,UUID会根据当前系统性能,时间戳等一系列参数经过运算得到一个全世界唯一的字符串,并且mysql提供了生成UUID的方法,用它作为主键能够保证数据的唯一性。

利用如下代码可以生成32位的UUID:

-- 生成32位UUID
SELECT REPLACE(UUID(),'-','') AS UUID;

在这里插入图片描述然后咱们再创建一个测试表:

CREATE TABLE test2(
  id VARCHAR(50) PRIMARY KEY,
  NAME VARCHAR(20) NOT NULL
)

插入一条数据:

-- 插入UUID
INSERT INTO test2 VALUES(REPLACE(UUID(),'-',''),'老王');

在这里插入图片描述
但这样写插入语句每次都要手写UUID函数,貌似有点太麻烦了,咱们可以写一个触发器,让触发器自动为我们设置ID:

-- 创建触发器
DELIMITER $$
CREATE
TRIGGER auto_id        -- 名称
BEFORE INSERT          -- 触发时机
ON test2 FOR EACH ROW   -- 作用于test2表,对每行数据生效
BEGIN
IF new.id = '' THEN     -- 当id为空字符串时设置UUID
  SET new.id = REPLACE(UUID(),'-','');
END IF;
END$$

插入一条数据:

-- 插入一条数据
INSERT INTO test2 VALUES('','小王');

结果能正常添加

在这里插入图片描述

总结

(1)用int型和bigInt型增删改查速度较UUID更快,并且更节省空间。
(2)用UUID更方便。

更详细的比较信息参考这篇博文:
MySQL 使用自增ID主键和UUID 作为主键的优劣比较详细过程(从百万到千万表记录测试)

MySQL中设置主键是一个非常常见的需求,这通常用于创建唯一标识每条记录的ID字段。当你希望每次插入新行时,这个主键值能够自动加而无需手动指定具体的数值。 ### 实现步骤: #### 1. 创建表时设定 `AUTO_INCREMENT` 当创建一个新的数据库表,并且想要其中某一列为自长列,则可以在建表语句里加上`AUTO_INCREMENT`关字来定义该属性。 ```sql CREATE TABLE users ( id INT AUTO_INCREMENT PRIMARY KEY, username VARCHAR(50), password CHAR(64) ); ``` 这里需要注意的是: - 自动递总是从1开始; - 如果删除了一些中间的数据再添加新的数据项,默认会继续往下数而不是填补空缺的位置; #### 2. 插入数据时不需提供自值 一旦设置了某列为自,在向这张表内插入数据的时候就不需要显式地给它赋值了,只需要填写其他非主键字段即可。 例如往上述users表格插入一行用户信息可以这么写: ```sql INSERT INTO users (username,password) VALUES ('exampleUser','hashedPassword'); ``` 此时这条命令将会按照顺序生成下一个可用id作为此用户的识别码。 #### 3. 获取刚刚插入记录的ID(可选) 有时候我们会在插入之后立即需要用到新加的那一行数据所对应的id编号,那么就可以利用 `LAST_INSERT_ID()` 函数获取到最近一次成功执行完insert操作后的返回结果: ```sql SELECT LAST_INSERT_ID(); ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值