[MySQL]MySQL如何做到無則插入有則更新(upsert)

問題場景

在排除一個(gè)生產(chǎn)BUG的時(shí)候發(fā)現(xiàn),有個(gè)關(guān)于庫存調(diào)撥的業(yè)務(wù)出現(xiàn)了唯一鍵沖突,最終定位到是設(shè)計(jì)表的時(shí)候,DDL設(shè)置了一個(gè)組合唯一索引。在重復(fù)插入一條業(yè)務(wù)數(shù)據(jù)的時(shí)候,觸發(fā)了這個(gè)數(shù)據(jù)庫的DUPLICATE KEY.
解決的辦法很簡單,做到"無則插入,有則更新"即可。

ON DUPLICATE KEY UPDATE

MySQL提供了ON DUPLICATE KEY UPDATE來解決這個(gè)問題.

insert into
    stock_prededuct_record(num,stockNumId,bizOrderId,bizOrderDetailId,bizType,bizNo,state,remark,stockOperateLogId,createTime)
    values
    (5,1,0,36277777,3,'XXX',1,'測試數(shù)據(jù)',0,now())
    ON DUPLICATE KEY UPDATE num = num + VALUES(num);

沒有這條數(shù)據(jù)的時(shí)候插入,有則累計(jì).
VALUES表示的是insert的時(shí)候num的值.

如果文章幫到了你解決問題,給作者點(diǎn)個(gè)贊吧~

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容