最常見的方式就是為字段設(shè)置主鍵或唯一索引涧偷,當(dāng)插入重復(fù)數(shù)據(jù)時簸喂,拋出錯誤,程序終止燎潮,但這會給后續(xù)處理帶來麻煩喻鳄,因此需要對插入語句做特殊處理,盡量避開或忽略異常确封,下面我簡單介紹一下除呵,感興趣的朋友可以嘗試一下:
這里為了方便演示,我新建了一個user測試表隅肥,主要有id竿奏,username袄简,sex腥放,address這4個字段,其中主鍵為id(自增)绿语,同時對username字段設(shè)置了唯一索引:
01 insert ignore into
即插入數(shù)據(jù)時秃症,如果數(shù)據(jù)存在,則忽略此次插入吕粹,前提條件是插入的數(shù)據(jù)字段設(shè)置了主鍵或唯一索引种柑,測試SQL語句如下,當(dāng)插入本條數(shù)據(jù)時匹耕,MySQL數(shù)據(jù)庫會首先檢索已有數(shù)據(jù)(也就是idx_username索引)聚请,如果存在,則忽略本次插入稳其,如果不存在驶赏,則正常插入數(shù)據(jù):
02 on duplicate key update
即插入數(shù)據(jù)時,如果數(shù)據(jù)存在既鞠,則執(zhí)行更新操作煤傍,前提條件同上,也是插入的數(shù)據(jù)字段設(shè)置了主鍵或唯一索引嘱蛋,測試SQL語句如下蚯姆,當(dāng)插入本條記錄時五续,MySQL數(shù)據(jù)庫會首先檢索已有數(shù)據(jù)(idx_username索引),如果存在龄恋,則執(zhí)行update更新操作疙驾,如果不存在,則直接插入:
03 replace into
即插入數(shù)據(jù)時郭毕,如果數(shù)據(jù)存在荆萤,則刪除再插入,前提條件同上铣卡,插入的數(shù)據(jù)字段需要設(shè)置主鍵或唯一索引链韭,測試SQL語句如下,當(dāng)插入本條記錄時煮落,MySQL數(shù)據(jù)庫會首先檢索已有數(shù)據(jù)(idx_username索引)敞峭,如果存在,則先刪除舊數(shù)據(jù)蝉仇,然后再插入旋讹,如果不存在,則直接插入:
04 insert if not exists
即insert into … select … where not exist ... 轿衔,這種方式適合于插入的數(shù)據(jù)字段沒有設(shè)置主鍵或唯一索引沉迹,當(dāng)插入一條數(shù)據(jù)時,首先判斷MySQL數(shù)據(jù)庫中是否存在這條數(shù)據(jù)害驹,如果不存在鞭呕,則正常插入,如果存在宛官,則忽略:
目前葫松,就分享這4種MySQL處理重復(fù)數(shù)據(jù)的方式吧,前3種方式適合字段設(shè)置了主鍵或唯一索引底洗,最后一種方式則沒有此限制腋么,只要你熟悉一下使用過程,很快就能掌握的亥揖,網(wǎng)上也有相關(guān)資料和教程珊擂,介紹的非常詳細(xì),感興趣的話费变,可以搜一下摧扇。