1. 程式人生 > 其它 >mysql 刪除重複資料_Mysql重複資料插入?用這4種方式高效避免

mysql 刪除重複資料_Mysql重複資料插入?用這4種方式高效避免

技術標籤:mysql 刪除重複資料mysql 插入mysql 插入慢mysql加欄位先判斷是否存在mysql怎樣迴圈插入資料mysql插入

點選上方“Java禿頭哥”,選擇“星標”

每天分享優質乾貨

707dcf34e5d0d4a378b817aebdec8cd0.gif

最常見的方式就是為欄位設定主鍵或唯一索引,當插入重複資料時,丟擲錯誤,程式終止,但這會給後續處理帶來麻煩,因此需要對插入語句做特殊處理,儘量避開或忽略異常,下面我簡單介紹一下,感興趣的朋友可以嘗試一下:

這裡為了方便演示,我新建了一個user測試表,主要有id,username,sex,address這4個欄位,其中主鍵為id(自增),同時對username欄位設定了唯一索引:

01 insert ignore into

即插入資料時,如果資料存在,則忽略此次插入,前提條件是插入的資料欄位設定了主鍵或唯一索引,測試SQL語句如下,當插入本條資料時,MySQL資料庫會首先檢索已有資料(也就是idx_username索引),如果存在,則忽略本次插入,如果不存在,則正常插入資料:

INSERTIGNOREINTOt_user(usename,sex,address)
VALUES
(
'java樂園',
'male',
'beijing'
);

02 on duplicate key update

即插入資料時,如果資料存在,則執行更新操作,前提條件同上,也是插入的資料欄位設定了主鍵或唯一索引,測試SQL語句如下,當插入本條記錄時,MySQL資料庫會首先檢索已有資料(idx_username索引),如果存在,則執行update更新操作,如果不存在,則直接插入:

INSERTINTOt_user(usename,sex,address)
VALUES
(
'java樂園',
'male',
'newyork'
)ONDUPLICATEKEYUPDATEsex='male',
address='beijing'

03 replace into

即插入資料時,如果資料存在,則刪除再插入,前提條件同上,插入的資料欄位需要設定主鍵或唯一索引,測試SQL語句如下,當插入本條記錄時,MySQL資料庫會首先檢索已有資料(idx_username索引),如果存在,則先刪除舊資料,然後再插入,如果不存在,則直接插入:

REPLACEINTOt_user(usename,sex,address)
VALUES
(
'java樂園',
'male',
'newyork'
);

04 insert if not exists

即insert into … select … where not exist ... ,這種方式適合於插入的資料欄位沒有設定主鍵或唯一索引,當插入一條資料時,首先判斷MySQL資料庫中是否存在這條資料,如果不存在,則正常插入,如果存在,則忽略:

INSERT
INTOt_user(usename,sex,address)SELECT
'java樂園',
'male',
'newyork'
FROM
t_user
WHERE
NOTEXISTS(
SELECT
username
FROM
t_user
WHERE
username='java樂園'
)

目前,就分享這4種MySQL處理重複資料的方式吧,前3種方式適合欄位設定了主鍵或唯一索引,最後一種方式則沒有此限制,只要你熟悉一下使用過程,很快就能掌握的,網上也有相關資料和教程,介紹的非常詳細,感興趣的話,可以搜一下。

--END--

1、生成後端模擬資料太慢了?用這個懶人工具效率提升60%!

2、提升10倍生產力:IDEA遠端一鍵部署SpringBoot到Docker

3、LinkedList 真的是查詢慢增刪快?重新整理你的認知!

4、感受lambda之美,推薦收藏,寫得太好了!

5、從 0 開始寫了個讀寫分離,不難嘛!

2020年秋招馬上就開始啦!我精選了45套大廠簡歷模版,需要的朋友關注公眾號並回復簡歷領取

84323cb024870994f8ea08bd071ec685.png

文章都看完了a42557421db042a756556f6729459f5c.gif不點個6a9313010275ca35db33940fed13d76a.png