MySQL 批量插入,如何不插入重復(fù)數(shù)據(jù)?
點擊上方“碼農(nóng)突圍”,馬上關(guān)注 這里是碼農(nóng)充電第一站,回復(fù)“666”,獲取一份專屬大禮包 真愛,請設(shè)置“星標(biāo)”或點個“在看”

來源:https://www.telami.cn/
溫故而知新
1、insert ignore into
當(dāng)插入數(shù)據(jù)時,如出現(xiàn)錯誤時,如重復(fù)數(shù)據(jù),將不返回錯誤,只以警告形式返回。所以使用ignore請確保語句本身沒有問題,否則也會被忽略掉。例如:
INSERT IGNORE INTO user (name) VALUES ('telami')
這種方法很簡便,但是有一種可能,就是插入不是因為重復(fù)數(shù)據(jù)報錯,而是因為其他原因報錯的,也同樣被忽略了~
2、on duplicate key update
INSERT INTO user (name) VALUES ('telami') ON duplicate KEY UPDATE id = id
3、insert … select … where not exist
INSERT INTO user (name) SELECT 'telami' FROM dual WHERE NOT EXISTS (SELECT id FROM user WHERE id = 1)
4、replace into
REPLACE INTO user SELECT 1, 'telami' FROM books
實踐
<insert id="batchSaveUser" parameterType="list">
insert into user (id,username,mobile_number)
values
<foreach collection="list" item="item" index="index" separator=",">
(
#{item.id},
#{item.username},
#{item.mobileNumber}
)
</foreach>
ON duplicate KEY UPDATE id = id
</insert>
- END - 最近熱文
? 尼瑪,Github上最邪惡的開源項目了!未滿18或者女孩子勿進(jìn)哦~ ? 永別了,91網(wǎng)站!宣布永久關(guān)閉 ? 騰訊員工曬出薪資:真實 985 畢業(yè)薪資,大家看我還有救嗎?網(wǎng)友:日薪? ? 再見深圳!我要去成都搞IT了!
評論
圖片
表情
