您现在的位置是:首页 > 编程语言学习 > 其他编程语言 > 文章正文 其他编程语言

MySQL创建唯一索引时报错Duplicate entry * for key问题

2022-09-27 10:01:17 其他编程语言

简介在MySQL表创建唯一索引时,出现报错Duplicate entry * for key.使用show index from table确认table中并不存在重名的唯一索引键名称...

在MySQL表创建唯一索引时,出现报错Duplicate entry * for key.

使用show index from table确认table中并不存在重名的唯一索引键名称。

解决

仔细看报错信息,根据那串ID数字,发现是表中出现违反创建的唯一索引键规则的重复数据,将此数据删除后创建唯一索引成功。


  1. ALTER TABLE person ADD UNIQUE `UNI_person_area`(`person_id`, `area_id`) USING BTREE COMMENT "人员重复"

MySQL唯一索引报错信息只显示前64位

MySQL的报错信息有时可能和大家预期的不一样,本文将根据实际案例演示最常见的唯一索引报错与预期情况有差异,不了解的同学可能以为有bug。

1.数据准备

1.1创建一个含唯一索引的表

-- 创建一张test表
  1. CREATE TABLE test ( 
  2.   id INT PRIMARY KEY AUTO_INCREMENT, 
  3.   c1 VARCHAR (31), 
  4.   c2 VARCHAR (32), 
  5.   c3 VARCHAR (8), 
  6.   c4 INT, 
  7.   UNIQUE KEY uq_c1_c2_c3 (c1, c2, c3) 
  8. ); 

1.2插入一批数据


  1. insert into `test` (`id`, `c1`, `c2`, `c3`, `c4`) values('1','90806443B5534D33B652929F5205E4F','5b612c194383488fad19e2889cf077f5','202204','1000000'); 
  2. insert into `test` (`id`, `c1`, `c2`, `c3`, `c4`) values('2','988806443B5534D33B652929F5205E4','077f55b612c194383488fad19e2889cf','202205','2000000'); 
  3. insert into `test` (`id`, `c1`, `c2`, `c3`, `c4`) values('3','988806443B5534D33B652929F5205E','5b612c194383488fad19e2889cf077f5','202204','1000000'); 

1.3插入一条唯一索引冲突的数据


  1. INSERT INTO `test` (`id`, `c1`, `c2`, `c3`, `c4`) VALUES('4','90806443B5534D33B652929F5205E4F','5b612c194383488fad19e2889cf077f5','202204',200000); 

报错信息如下:

错误代码:1062Duplicate entry '90806443B5534D33B652929F5205E4F-5b612c194383488fad19e2889cf077f5'for key 'uq_c1_c2_c3'

报错信息中只有c1(90806443B5534D33B652929F5205E4F)和c2(5b612c194383488fad19e2889cf077f5)的值,无c3(202204)的值,有时如果批量插入过多的行时,无法快速定位哪一行冲突,不便于快速排查问题。

2.原因探索

从报错信息中可以发现,c1、c2、'-'连接符总长度为64个字符,可以从源码着手。

在源码 errmsg-utf8 文件中,可以发现有如下信息:


  1. eng "Duplicate entry '%-.64s' for key '%-.192s'" 

也就是,报错信息中内容的有64个字符,key的名字为192个字符,至此揭开了谜底。

相关文章

站点信息