MySQL INSERT插入條件判斷:如果不存在則插入

我們經常需要進行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

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章