我們經常需要進行sql的批量插入,要求:該條記錄不存在則插入,存在則不插入。如果使用一條INSERT語句實現呢?
對於普通的 INSERT 插入,如果想要保證不插入重複記錄,我們只有對某個字段創建唯一約束實現;
那有沒有不創建唯一約束,僅通過 INSERT INTO 一條語句實現的方案呢?
答:使用 INSERT INTO IF EXISTS, 具體語法如下
INSERT INTO table(field1, field2, fieldn)
SELECT 'field1', 'field2', 'fieldn'
FROM DUAL
WHERE NOT EXISTS(SELECT field FROM table WHERE field = ?)
例:
INSERT INTO a (order_id, operator, oper_date, memo)
SELECT '3', 'onion3', '2017-11-28', '測試3'
from DUAL
where not exists(select order_id from a where operator='onion3' and memo = '測試3');
原文:https://blog.csdn.net/qq_33212500/article/details/80339997