最常見的方式就是為字段設置主鍵或唯一索引,當插入重復數(shù)據(jù)時,拋出錯誤,程序終止,但這會給后續(xù)處理帶來麻煩,因此需要對插入語句做特殊處理,盡量避開或忽略異常,下面我簡單介紹一下,感興趣的朋友可以嘗試一下:
這里為了方便演示,我新建了一個user測試表,主要有id,username,sex,address這4個字段,其中主鍵為id(自增),同時對username字段設置了唯一索引:
01 insert ignore into
即插入數(shù)據(jù)時,如果數(shù)據(jù)存在,則忽略此次插入,前提條件是插入的數(shù)據(jù)字段設置了主鍵或唯一索引,測試SQL語句如下,當插入本條數(shù)據(jù)時,MySQL數(shù)據(jù)庫會首先檢索已有數(shù)據(jù)(也就是idx_username索引),如果存在,則忽略本次插入,如果不存在,則正常插入數(shù)據(jù):

02 on duplicate key update
即插入數(shù)據(jù)時,如果數(shù)據(jù)存在,則執(zhí)行更新操作,前提條件同上,也是插入的數(shù)據(jù)字段設置了主鍵或唯一索引,測試SQL語句如下,當插入本條記錄時,MySQL數(shù)據(jù)庫會首先檢索已有數(shù)據(jù)(idx_username索引),如果存在,則執(zhí)行update更新操作,如果不存在,則直接插入:

03 replace into
即插入數(shù)據(jù)時,如果數(shù)據(jù)存在,則刪除再插入,前提條件同上,插入的數(shù)據(jù)字段需要設置主鍵或唯一索引,測試SQL語句如下,當插入本條記錄時,MySQL數(shù)據(jù)庫會首先檢索已有數(shù)據(jù)(idx_username索引),如果存在,則先刪除舊數(shù)據(jù),然后再插入,如果不存在,則直接插入:

04 insert if not exists
即insert into … select … where not exist ... ,這種方式適合于插入的數(shù)據(jù)字段沒有設置主鍵或唯一索引,當插入一條數(shù)據(jù)時,首先判斷MySQL數(shù)據(jù)庫中是否存在這條數(shù)據(jù),如果不存在,則正常插入,如果存在,則忽略:

目前,就分享這4種MySQL處理重復數(shù)據(jù)的方式吧,前3種方式適合字段設置了主鍵或唯一索引,最后一種方式則沒有此限制,只要你熟悉一下使用過程,很快就能掌握的,網(wǎng)上也有相關資料和教程,介紹的非常詳細,感興趣的話,可以搜一下
到此這篇關于Mysql避免重復插入數(shù)據(jù)的4種方式的文章就介紹到這了,更多相關Mysql避免重復插入數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- 防止MySQL重復插入數(shù)據(jù)的三種方法
- MySql三種避免重復插入數(shù)據(jù)的方法
- MySQL使用UNIQUE實現(xiàn)數(shù)據(jù)不重復插入
- 防止mysql重復插入記錄的方法
- MySql避免重復插入記錄的幾種方法