MySQL--更新自增列的潜在风险

栏目: 数据库 · 发布时间: 5年前

内容简介:##=====================================================================##测试环境:MySQL版本:MySQL 5.7.19

##=====================================================================##

测试环境:

MySQL版本:MySQL 5.7.19

复制模式:ROW

##=====================================================================##

执行下面语句:

## 创建测试表
DROP TABLE T_001;
CREATE TABLE `T_001` (
  `ID` int(11) NOT NULL AUTO_INCREMENT,
  `C1` int(11) NOT NULL,
  PRIMARY KEY (`ID`),
  UNIQUE KEY `UNI_C1` (`C1`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

##插入记录
INSERT INTO T_001(C1)VALUES(1);

##更新ID列
UPDATE T_001
SET ID=2,
C1=2
WHERE C1=1;

##插入新记录
INSERT INTO T_001(C1)VALUES(3);

执行报错:

ERROR 1062 (23000): Duplicate entry '2' for key 'PRIMARY'

##=====================================================================##

原因分析:

1、第一次INSERT语句,获得自增值为1。

2、UPDATE操作完成,将表中数据的ID列修改为2,但UPDATE操作不会触发表的自增起始值发生变化。

3、第二次INSERT语句,获得自增值为2,由于表中已存在ID=2的记录,因此插入失败,报主键重复。

##=====================================================================##

总结:

1、对于自增列,其自增值与业务无关,应避免对自增列数据进行更新操作,避免出现异常。

##=====================================================================##

MySQL--更新自增列的潜在风险


以上所述就是小编给大家介绍的《MySQL--更新自增列的潜在风险》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

缺失的终结

缺失的终结

【美】克尔•哈里斯 / 艾博 / 中国人民大学出版社 / 2017-6-15 / 39.00元

《缺失的终结》是一本反思互联网时代对普通人日常生活影响的书。作者认为,我们都曾渴望有一段远离现实生活烦扰的“瓦尔登湖”时光,悠闲地沉入自己的内心世界,从飞速变化的漩涡中暂时“缺失”。然而,互联网生活让我们每时每刻被互联网化,手环监测着我们的心跳和睡眠,微信、脸书、推特让我们人在床上就与世界链接起来,跑步了吗?走路了吗?英语单词背了吗?早餐的卡路里是否超标?坐在办公室,无数亟待处理的信息狂风暴雨般地......一起来看看 《缺失的终结》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

随机密码生成器
随机密码生成器

多种字符组合密码

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具