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

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

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

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

目前,就分享這4種MySQL處理重復(fù)數(shù)據(jù)的方式吧,前3種方式適合字段設(shè)置了主鍵或唯一索引,最后一種方式則沒(méi)有此限制,只要你熟悉一下使用過(guò)程,很快就能掌握的,網(wǎng)上也有相關(guān)資料和教程,介紹的非常詳細(xì),感興趣的話,可以搜一下
到此這篇關(guān)于Mysql避免重復(fù)插入數(shù)據(jù)的4種方式的文章就介紹到這了,更多相關(guān)Mysql避免重復(fù)插入數(shù)據(jù)內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. DB2 與 Microsoft SQL Server 2000 之間的 SQL 數(shù)據(jù)復(fù)制2. 細(xì)化解析:Oracle 10g ASM 的一點(diǎn)經(jīng)驗(yàn)3. DB2 XML 全文搜索之為文本搜索做準(zhǔn)備4. MyBatis中$和#的深入講解5. 國(guó)內(nèi)學(xué)院派專家對(duì)DB2 9新產(chǎn)品贊不絕口6. 解讀Oracle中代替like進(jìn)行模糊查詢的方法instr(更高效)7. Mybatis 自動(dòng)映射(使用需謹(jǐn)慎)8. MySQL Shell的介紹以及安裝9. 使用 Database Access(數(shù)據(jù)庫(kù)訪問(wèn))組件10. MySQL中庫(kù)的基本操作指南(推薦!)

網(wǎng)公網(wǎng)安備