MySQL創(chuàng)建唯一索引時(shí)報(bào)錯(cuò)Duplicate?entry?*?for?key問題
創(chuàng)建唯一索引時(shí)報(bào)錯(cuò)Duplicate entry * for key
場景
在MySQL表創(chuàng)建唯一索引時(shí),出現(xiàn)報(bào)錯(cuò)Duplicate entry * for key.

使用show index from table確認(rèn)table中并不存在重名的唯一索引鍵名稱。
解決
仔細(xì)看報(bào)錯(cuò)信息,根據(jù)那串ID數(shù)字,發(fā)現(xiàn)是表中出現(xiàn)違反創(chuàng)建的唯一索引鍵規(guī)則的重復(fù)數(shù)據(jù),將此數(shù)據(jù)刪除后創(chuàng)建唯一索引成功。
ALTER TABLE person ADD UNIQUE `UNI_person_area`(`person_id`, `area_id`) USING BTREE COMMENT "人員重復(fù)";
MySQL唯一索引報(bào)錯(cuò)信息只顯示前64位
MySQL的報(bào)錯(cuò)信息有時(shí)可能和大家預(yù)期的不一樣,本文將根據(jù)實(shí)際案例演示最常見的唯一索引報(bào)錯(cuò)與預(yù)期情況有差異,不了解的同學(xué)可能以為有bug。
1.數(shù)據(jù)準(zhǔn)備
1.1創(chuàng)建一個(gè)含唯一索引的表
-- 創(chuàng)建一張test表 CREATE TABLE test ( ? id INT PRIMARY KEY AUTO_INCREMENT, ? c1 VARCHAR (31), ? c2 VARCHAR (32), ? c3 VARCHAR (8), ? c4 INT, ? UNIQUE KEY uq_c1_c2_c3 (c1, c2, c3) );
1.2插入一批數(shù)據(jù)
insert into `test` (`id`, `c1`, `c2`, `c3`, `c4`) values('1','90806443B5534D33B652929F5205E4F','5b612c194383488fad19e2889cf077f5','202204','1000000');
insert into `test` (`id`, `c1`, `c2`, `c3`, `c4`) values('2','988806443B5534D33B652929F5205E4','077f55b612c194383488fad19e2889cf','202205','2000000');
insert into `test` (`id`, `c1`, `c2`, `c3`, `c4`) values('3','988806443B5534D33B652929F5205E','5b612c194383488fad19e2889cf077f5','202204','1000000');1.3插入一條唯一索引沖突的數(shù)據(jù)
INSERT INTO `test` (`id`, `c1`, `c2`, `c3`, `c4`) VALUES('4','90806443B5534D33B652929F5205E4F','5b612c194383488fad19e2889cf077f5','202204',200000);報(bào)錯(cuò)信息如下:
錯(cuò)誤代碼:1062
Duplicate entry '90806443B5534D33B652929F5205E4F-5b612c194383488fad19e2889cf077f5'
for key 'uq_c1_c2_c3'
報(bào)錯(cuò)信息中只有c1(90806443B5534D33B652929F5205E4F)和c2(5b612c194383488fad19e2889cf077f5)的值,無c3(202204)的值,有時(shí)如果批量插入過多的行時(shí),無法快速定位哪一行沖突,不便于快速排查問題。
2.原因探索
從報(bào)錯(cuò)信息中可以發(fā)現(xiàn),c1、c2、'-'連接符總長度為64個(gè)字符,可以從源碼著手。
在源碼 errmsg-utf8 文件中,可以發(fā)現(xiàn)有如下信息:
eng "Duplicate entry '%-.64s' for key '%-.192s'"
也就是,報(bào)錯(cuò)信息中內(nèi)容的有64個(gè)字符,key的名字為192個(gè)字符,至此揭開了謎底。
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
driver-class-name:?com.mysql.jdbc.Driver爆紅的問題解決
在springboot項(xiàng)目工程中想要進(jìn)行數(shù)據(jù)庫配置,driver-class-name:?com.mysql.cj.jdbc.Driver始終報(bào)錯(cuò),本文就來介紹一下如何解決,感興趣的可以了解一下2024-07-07
Windows系統(tǒng)下MySQL忘記root密碼的2種解決辦法
這篇文章主要介紹了Windows系統(tǒng)下MySQL忘記root密碼的2種解決辦法,一種是通過啟動(dòng)MySQL時(shí)跳過權(quán)限表驗(yàn)證,然后重置密碼,另一種是創(chuàng)建一個(gè)包含新密碼的文本文件,并通過MySQL的--init-file選項(xiàng)來應(yīng)用該文件中的密碼設(shè)置,需要的朋友可以參考下2024-11-11
MySQL5.7升級MySQL8.0的完整卸載與安裝及連接Navicat的步驟
因?yàn)橐粋€(gè)項(xiàng)目交接需要需要將mysql物理備份文件還原至MySQL5.7,并且將mysql5.7升級到MySQL8.0,下面這篇文章主要給大家介紹了關(guān)于MySQL5.7升級MySQL8.0的完整卸載與安裝及連接Navicat的相關(guān)資料,需要的朋友可以參考下2023-03-03
MySql三種避免重復(fù)插入數(shù)據(jù)的方法
這篇文章主要介紹了MySql三種避免重復(fù)插入數(shù)據(jù)的方法,幫助大家更好的理解和使用MySQL數(shù)據(jù)庫,感興趣的朋友可以了解下2020-09-09
Ubuntu?服務(wù)器安裝?MySQL?遠(yuǎn)程數(shù)據(jù)庫的方法
本篇介紹如何在 Linux 服務(wù)器上安裝 MySQL 數(shù)據(jù)庫,并設(shè)置為可遠(yuǎn)程連接,本文通過命令給大家介紹的非常詳細(xì),對Ubuntu?安裝?MySQL遠(yuǎn)程數(shù)據(jù)庫感興趣的朋友一起看看吧2022-08-08
mysql-5.5.28源碼安裝過程中錯(cuò)誤總結(jié)
介紹一下關(guān)于mysql-5.5.28源碼安裝過程中幾大錯(cuò)誤總結(jié),希望此文章對各位同學(xué)有所幫助。2013-10-10
MYSQL row_number()與over()函數(shù)用法詳解
這篇文章主要介紹了MYSQL row_number()與over()函數(shù)用法詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-08-08
DB為何大量出現(xiàn)select @@session.tx_read_only 詳解
這篇文章主要給大家介紹了關(guān)于DB為何大量出現(xiàn)select @@session.tx_read_only 的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2018-04-04

