MySQL 是一種開源的關(guān)系型數(shù)據(jù)庫管理系統(tǒng),具有高可靠性、安全性、靈活性等特點(diǎn)。在 MySQL 中,插入數(shù)據(jù)時(shí)通常會(huì)遇到重復(fù)數(shù)據(jù)的問題,可能導(dǎo)致數(shù)據(jù)沖突和錯(cuò)誤,因此需要設(shè)置插入數(shù)據(jù)不允許重復(fù)。
CREATE TABLE score( id INT PRIMARY KEY, name VARCHAR(20) UNIQUE, score INT );
在上面的代碼中,UNIQUE 關(guān)鍵字用于創(chuàng)建一個(gè)名為 name 的唯一約束,確保插入的數(shù)據(jù)每個(gè) name 值都是唯一的。當(dāng)嘗試插入重復(fù)的 name 值時(shí),MySQL會(huì)報(bào)錯(cuò)。
INSERT INTO score (id, name, score) VALUES (1, 'Tom', 90);
插入數(shù)據(jù)時(shí)可以使用 INSERT INTO 語句,將數(shù)據(jù)插入到名為 score 的表中。在上面的代碼中,嘗試插入一個(gè)已存在的 name 值 'Tom',MySQL會(huì)報(bào)如下錯(cuò)誤:
ERROR 1062 (23000): Duplicate entry 'Tom' for key 'name'
這是因?yàn)槲覀冊趧?chuàng)建表時(shí)使用了 UNIQUE 約束,限制了 name 列的值必須唯一,而嘗試插入存在的值導(dǎo)致約束條件不滿足,因此出現(xiàn)重復(fù)鍵錯(cuò)誤。
總之,設(shè)置插入數(shù)據(jù)不允許重復(fù)可以有效地防止數(shù)據(jù)重復(fù)和錯(cuò)誤,保證數(shù)據(jù)的完整性和準(zhǔn)確性。