MySQL 批量插入,如何不插入重復(fù)數(shù)據(jù)?
閱讀本文大概需要 2.3 分鐘。
來自:www.telami.cn
溫故而知新
1、insert ignore into
當插入數(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>
推薦閱讀:
數(shù)據(jù)庫連接池為什么要用threadlocal呢?不用會怎樣?
最近面試BAT,整理一份面試資料《Java面試BATJ通關(guān)手冊》,覆蓋了Java核心技術(shù)、JVM、Java并發(fā)、SSM、微服務(wù)、數(shù)據(jù)庫、數(shù)據(jù)結(jié)構(gòu)等等。
朕已閱 

