mysql的判断更新_mysql判断记录是否存在,存在则更新,不存在则插入
向數(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)題。
- 上一篇: 个性签名4字
- 下一篇: window mysql 字符集_Win