
MySQL數(shù)據(jù)庫(kù)避免重復(fù)的插入數(shù)據(jù)
聲明:該文章由作者(amybebe)發(fā)表,轉(zhuǎn)載此文章須經(jīng)作者同意并請(qǐng)附上出處(0XUCN)及本頁(yè)鏈接。。
最常見的方式就是為字段設(shè)置主鍵或唯一索引,當(dāng)插入重復(fù)數(shù)據(jù)時(shí),拋出錯(cuò)誤,程序終止,但這會(huì)給后續(xù)處理帶來麻煩,因此需要對(duì)插入語句做特殊處理,盡量避開或忽略異常,下面我簡(jiǎn)單介紹一下,感興趣的朋友可以嘗試一下:
這里為了方便演示,我新建了一個(gè)user測(cè)試表,主要有id,username,sex,address這4個(gè)字段,其中主鍵為id(自增),同時(shí)對(duì)username字段設(shè)置了唯一索引:
01insert ignore into
即插入數(shù)據(jù)時(shí),如果數(shù)據(jù)存在,則忽略此次插入,前提條件是插入的數(shù)據(jù)字段設(shè)置了主鍵或唯一索引,測(cè)試SQL語句如下,當(dāng)插入本條數(shù)據(jù)時(shí),MySQL數(shù)據(jù)庫(kù)會(huì)首先檢索已有數(shù)據(jù)(也就是idx_username索引),如果存在,則忽略本次插入,如果不存在,則正常插入數(shù)據(jù):
02on duplicate key update
即插入數(shù)據(jù)時(shí),如果數(shù)據(jù)存在,則執(zhí)行更新操作,前提條件同上,也是插入的數(shù)據(jù)字段設(shè)置了主鍵或唯一索引,測(cè)試SQL語句如下,當(dāng)插入本條記錄時(shí),MySQL數(shù)據(jù)庫(kù)會(huì)首先檢索已有數(shù)據(jù)(idx_username索引),如果存在,則執(zhí)行update更新操作,如果不存在,則直接插入:
03replace into
即插入數(shù)據(jù)時(shí),如果數(shù)據(jù)存在,則刪除再插入,前提條件同上,插入的數(shù)據(jù)字段需要設(shè)置主鍵或唯一索引,測(cè)試SQL語句如下,當(dāng)插入本條記錄時(shí),MySQL數(shù)據(jù)庫(kù)會(huì)首先檢索已有數(shù)據(jù)(idx_username索引),如果存在,則先刪除舊數(shù)據(jù),然后再插入,如果不存在,則直接插入:
04insert if not exists
即insert into … select … where not exist ... ,這種方式適合于插入的數(shù)據(jù)字段沒有設(shè)置主鍵或唯一索引,當(dāng)插入一條數(shù)據(jù)時(shí),首先判斷MySQL數(shù)據(jù)庫(kù)中是否存在這條數(shù)據(jù),如果不存在,則正常插入,如果存在,則忽略:
目前,就分享這4種MySQL處理重復(fù)數(shù)據(jù)的方式吧,前3種方式適合字段設(shè)置了主鍵或唯一索引,最后一種方式則沒有此限制
[超站]友情鏈接:
四季很好,只要有你,文娛排行榜:https://www.yaopaiming.com/
關(guān)注數(shù)據(jù)與安全,洞悉企業(yè)級(jí)服務(wù)市場(chǎng):https://www.ijiandao.com/
- 1 “開創(chuàng)新疆更加美好的明天” 7904780
- 2 小孩姐扛著“東風(fēng)-5C”走進(jìn)幼兒園 7808484
- 3 舞者解曉東去世 曾摔傷腦部重度昏迷 7713154
- 4 國(guó)慶中秋假期各地天氣最新預(yù)報(bào) 7617076
- 5 特斯拉技術(shù)員被機(jī)器人打成重傷 7520736
- 6 兩名15歲失聯(lián)少女已被越南警方攔截 7424276
- 7 黃仁勛稱中國(guó)芯片僅落后美國(guó)幾納秒 7333410
- 8 媽媽因兒子成績(jī)“三連跌”怒退機(jī)票 7235569
- 9 中方?jīng)Q定:增設(shè)K字簽證 7142558
- 10 清華兩教職工當(dāng)“黃?!北痪?/a> 7045330