詳解MySql如何不插入重復數據
向數據庫的插入值時,需要判斷插入是否重復,然后插入。
這種操作怎么提高效率
下面說說一些解決方案
1、insert ignore into
當插入數據時,如出現錯誤時,如重復數據,將不返回錯誤,只以警告形式返回。所以使用ignore請確保語句本身沒有問題,否則也會被忽略掉。例如:
INSERT IGNORE INTO USER ( NAME ) VALUES ( '張三' );
這種方法很簡單,但是有一種可能插入不是因為重復數據報錯,而是因為其他原因報錯的,也同樣被忽略了~
2、on duplicate key update
當primary 或者 unique重復時,則執(zhí)行update語句;
當update后為無用語句,如:id=id,錯誤不會被忽略。
INSERT INTO USER ( NAME ) VALUES ( '張三' ) ON DUPLICATE KEY UPDATE id = id;
這種方法有個前提條件,就是需要約束條件,即,主鍵或者唯一約束。
3、insert ... select ... where not exist
根據select的條件判斷是否插入
INSERT INTO USER ( NAME ) SELECT '張三' FROM DUAL WHERE NOT EXISTS (SELECT id FROM USER WHERE id = 1)
這種方法其實就是使用mysql的一個臨時表的方式,但是里面使用子查詢,效率會有影響,能不使用盡量避免。
4、replace into
如果存在 primary 或者 unique 相同的記錄,則先刪除再插入新記錄。
REPLACE INTO USER SELECT 1, '張三' FROM USER
這種方法就是不管原來有沒有相同的記錄,都會先刪除再插入。
到此這篇關于詳解MySql如何不插入重復數據的文章就介紹到這了,更多相關MySql不插入重復數據內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!