日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 人文社科 > 生活经验 >内容正文

生活经验

mysql的判断更新_mysql判断记录是否存在,存在则更新,不存在则插入

發(fā)布時(shí)間:2023/11/27 生活经验 46 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql的判断更新_mysql判断记录是否存在,存在则更新,不存在则插入 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

向數(shù)據(jù)庫(kù)插入記錄時(shí),有時(shí)會(huì)有這種需求,當(dāng)符合某種條件的數(shù)據(jù)存在時(shí),去修改它,不存在時(shí),則新增,也就是saveOrUpdate操作。這種控制可以放在業(yè)務(wù)層,也可以放在數(shù)據(jù)庫(kù)層,大多數(shù)數(shù)據(jù)庫(kù)都支持這種需求,如Oracle的merge語(yǔ)句,再如本文所講的MySQL中的INSERT ... ON DUPLICATE KEY UPDATE語(yǔ)句。

該語(yǔ)句是基于唯一索引或主鍵使用,比如一個(gè)字段a被加上了unique index,并且表中已經(jīng)存在了一條記錄值為1,下面兩個(gè)語(yǔ)句會(huì)有相同的效果:

INSERT?INTO?table?(a,b,c)?VALUES?(1,2,3)

ON?DUPLICATE?KEY?UPDATE?c=c+1;

UPDATE?table?SET?c=c+1?WHERE?a=1;

ON DUPLICATE KEY UPDATE后面可以放多個(gè)字段,用英文逗號(hào)分割。使用ON DUPLICATE KEY UPDATE,最終如果插入了一個(gè)新行,則受影響的行數(shù)是1,如果修改了已存在的一行數(shù)據(jù),則受影響的行數(shù)是2。

如果字段b也被加上了unique index,則該語(yǔ)句和下面的update語(yǔ)句是等效的:

UPDATE?table?SET?c=c+1?WHERE?a=1?OR?b=2?LIMIT?1;

如果a=1 OR b=2匹配了多行,則只有一行會(huì)被修改。通常的,在ON DUPLICATE KEY UPDATE語(yǔ)句中,我們應(yīng)該避免多個(gè)唯一索引的情況。如果需要插入或更新多條數(shù)據(jù),并且更新的字段需要根據(jù)其它字段來(lái)運(yùn)算時(shí),可以使用如下語(yǔ)句:

INSERT?INTO?table?(a,b,c)?VALUES?(1,2,3),(4,5,6)

ON?DUPLICATE?KEY?UPDATE?c=VALUES(a)+VALUES(b);

在ON DUPLICATE KEY UPDATE后面使用VALUES()方法,這個(gè)語(yǔ)句等同于下面的兩個(gè)語(yǔ)句:

INSERT?INTO?table?(a,b,c)?VALUES?(1,2,3)

ON?DUPLICATE?KEY?UPDATE?c=3;--1+2

INSERT?INTO?table?(a,b,c)?VALUES?(4,5,6)

ON?DUPLICATE?KEY?UPDATE?c=9;--4+5

如果一個(gè)表中包含了一個(gè)auto_increment的字段,每次insert數(shù)據(jù)后,可以通過(guò)last_insert_id()方法返回最后自動(dòng)生成的值,如果通過(guò)INSERT ... ON DUPLICATE KEY UPDATE語(yǔ)句修改了一條數(shù)據(jù),那么再通過(guò)last_insert_id()方法獲取的值將不正確,實(shí)際測(cè)試中是多了一個(gè)數(shù),比如向表中增加了3條數(shù)據(jù),那么通過(guò)last_insert_id()方法得到的值是3,但是通過(guò)該語(yǔ)句修改了一條數(shù)據(jù)后,通過(guò)last_insert_id()方法得到的值是4。如果想解決該問(wèn)題,可以通過(guò)如下語(yǔ)句:

INSERT?INTO?table?(a,b,c)?VALUES?(1,2,3)

ON?DUPLICATE?KEY?UPDATE?id=LAST_INSERT_ID(id),?c=3;

重點(diǎn)是這句id=LAST_INSERT_ID(id)。

INSERT INTO ON DUPLICATE KEY UPDATE 與 REPLACE INTO,兩個(gè)命令可以處理重復(fù)鍵值問(wèn)題,在實(shí)際上它之間有什么區(qū)別呢?

前提條件是這個(gè)表必須有一個(gè)唯一索引或主鍵。

1、REPLACE發(fā)現(xiàn)重復(fù)的先刪除再插入,如果記錄有多個(gè)字段,在插入的時(shí)候如果有的字段沒(méi)有賦值,那么新插入的記錄這些字段為空。

2、INSERT發(fā)現(xiàn)重復(fù)的是更新操作。在原有記錄基礎(chǔ)上,更新指定字段內(nèi)容,其它字段內(nèi)容保留。

這樣REPLACE的操作成本要大于 insert??ON DUPLICATE KEY UPDATE ,按道理應(yīng)該選用insert??ON DUPLICATE KEY UPDATE

測(cè)試:

/**/

INSERT INTO `fuwu_wuliu_info` VALUES (0,'aaa','bb','123','456','北京','北京','朝陽(yáng)','大望路','',NOW()) ON DUPLICATE KEY UPDATE

`nick`='dd',`receiver`='11',`mobile`='0000',`telephone`='789',`province`='上海',`city`='上海',`area`='寶山',`address`='----',`remark`='無(wú)',`addtime`=NOW()

/**/

REPLACE ?INTO `fuwu_wuliu_info` VALUES (0,'aa3','bb','123','456','河南','河南','河南','河南','',NOW())

總結(jié)

以上是生活随笔為你收集整理的mysql的判断更新_mysql判断记录是否存在,存在则更新,不存在则插入的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。