參考:MySQL8.0使用手冊(cè)
使用須知:
- 通常,您應(yīng)該盡量避免ON DUPLICATE KEY UPDATE 在具有多個(gè)唯一索引的表上使用子句,有可能會(huì)造成鎖問題從而影響性能;
- ON DUPLICATE KEY UPDATE子句可以包含多個(gè)列分配,以逗號(hào)分隔;
- ON DUPLICATE KEY UPDATE可以利用INSERT字句的VALUES來進(jìn)行賦值,比如:
INSERT INTO t1 (a,b,c) VALUES (1,2,3),(4,5,6)
ON DUPLICATE KEY UPDATE c=VALUES(a)+VALUES(b);
關(guān)于返回
- 對(duì)于ON DUPLICATE KEY UPDATE,如果將行作為新行插入,則每行的受影響行值為1;
- 如果更新現(xiàn)有行,則為2,如果現(xiàn)有行設(shè)置為其當(dāng)前值,則為0;
- 如果在連接到mysqld時(shí)指定C API函數(shù)的 CLIENT_FOUND_ROWS標(biāo)志,則 如果將現(xiàn)有行設(shè)置為其當(dāng)前值,則affected-rows值為1(不為0)。
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。