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

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 人文社科 > 生活经验 >内容正文

生活经验

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

發布時間:2023/11/27 生活经验 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mysql的判断更新_mysql判断记录是否存在,存在则更新,不存在则插入 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

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

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

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后面可以放多個字段,用英文逗號分割。使用ON DUPLICATE KEY UPDATE,最終如果插入了一個新行,則受影響的行數是1,如果修改了已存在的一行數據,則受影響的行數是2。

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

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

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

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()方法,這個語句等同于下面的兩個語句:

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

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

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

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

重點是這句id=LAST_INSERT_ID(id)。

INSERT INTO ON DUPLICATE KEY UPDATE 與 REPLACE INTO,兩個命令可以處理重復鍵值問題,在實際上它之間有什么區別呢?

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

1、REPLACE發現重復的先刪除再插入,如果記錄有多個字段,在插入的時候如果有的字段沒有賦值,那么新插入的記錄這些字段為空。

2、INSERT發現重復的是更新操作。在原有記錄基礎上,更新指定字段內容,其它字段內容保留。

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

測試:

/**/

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

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

/**/

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

總結

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

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。