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判断记录是否存在,存在则更新,不存在则插入的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 个性签名4字
- 下一篇: window mysql 字符集_Win