欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mysql如何實(shí)現(xiàn)不存在則插入,存在則更新

 更新時(shí)間:2022年03月25日 09:25:55   作者:fukaiit  
這篇文章主要介紹了Mysql如何實(shí)現(xiàn)不存在則插入,存在則更新,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

數(shù)據(jù)準(zhǔn)備

ON DUPLICATE KEY UPDATE

insert into test_table(id,username)
VALUES(4,'fukaiit')
ON DUPLICATE KEY UPDATE username='fukaiit'

執(zhí)行如上sql,該id不存在(此處id不存在,指的是id為X的記錄不存在,包括主鍵、unique索引列等情況),相當(dāng)于執(zhí)行了insert部分,普通插入,受影響的行:1。

insert into test_table(id,username)
VALUES(1,'fukaiit')
ON DUPLICATE KEY UPDATE username='fukaiit'

執(zhí)行如上sql,該id已存在,相當(dāng)于執(zhí)行了update部分,受影響的行:2。

執(zhí)行結(jié)果如下,注意只是更新username,是保留了email的。

REPLACE INTO … VALUES…

REPLACE INTO test_table(id,username)
VALUES(5,'fukaiit');

執(zhí)行如上sql,該id不存在,相當(dāng)于執(zhí)行了insert,普通插入,受影響的行:1。

REPLACE INTO test_table(id,username)
VALUES(1,'fukaiit');

執(zhí)行如上sql,該id已存在,相當(dāng)于執(zhí)行了刪除再插入的操作,受影響的行:2。

執(zhí)行結(jié)果如下,注意刪除后再插入是沒(méi)有email值的,所以此時(shí)email為null,注意與ON DUPLICATE KEY UPDATE的區(qū)別。

無(wú)論是insert on duplicate key update還是replace into,在插入時(shí)MySQL返回的影響行數(shù)就是插入的記錄數(shù),但是在更新時(shí)返回的影響行數(shù)是更新行數(shù)*2。

INSERT IGNORE INTO … VALUES…

INSERT IGNORE INTO test_table(id,username)?
values(6,'fukaiit');

執(zhí)行如上sql,該id不存在,相當(dāng)于執(zhí)行了insert,普通插入,受影響的行:1。

INSERT IGNORE INTO test_table(id,username)?
values(1,'fukaiit_new');

執(zhí)行如上sql,該id已存在,忽略了該插入操作,數(shù)據(jù)沒(méi)有變化,受影響的行:0。

使用DUAL虛表和NOT EXISTS

該方法與INSERT IGNORE INTO ... VALUES...方法的效果相同。

INSERT INTO test_table(id,username)
SELECT 7,'fukaiit' from DUAL?
where NOT EXISTS (select * from test_table where id=7);

執(zhí)行如上sql,該id不存在,select子句返回結(jié)果集為空,NOT EXISTS成立,相當(dāng)于執(zhí)行了insert,普通插入,受影響的行:1。

INSERT INTO test_table(id,username)
SELECT 2,'fukaiit' from DUAL?
where NOT EXISTS (select * from test_table where id=2);

執(zhí)行如上sql,該id已存在,select子句返回結(jié)果集不為空,NOT EXISTS不成立,則未執(zhí)行插入操作,數(shù)據(jù)沒(méi)有變化,受影響的行:0。

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • mysql 中 replace into 與 insert into on duplicate key update 的用法和不同點(diǎn)實(shí)例分析

    mysql 中 replace into 與 insert into on duplicate key update 的

    這篇文章主要介紹了mysql 中 replace into 與 insert into on duplicate key update 的用法和不同點(diǎn),結(jié)合實(shí)例形式分析了replace into 與 insert into on duplicate key update的功能、基本用法與操作注意事項(xiàng),需要的朋友可以參考下
    2020-02-02
  • FROM_UNIXTIME 格式化MYSQL時(shí)間戳函數(shù)

    FROM_UNIXTIME 格式化MYSQL時(shí)間戳函數(shù)

    對(duì)MYSQL沒(méi)有進(jìn)行過(guò)深入的研究,基礎(chǔ)知識(shí)匱乏,一遇到問(wèn)題只能手冊(cè),看來(lái)要把MYSQL的學(xué)習(xí)安排進(jìn)時(shí)間表了。
    2011-04-04
  • SQL SERVER 2005 最小安裝經(jīng)驗(yàn)

    SQL SERVER 2005 最小安裝經(jīng)驗(yàn)

    很久以前有個(gè)疑問(wèn) 安裝SQL SERVER 2005后為什么會(huì)把VS2005給裝上了,當(dāng)時(shí)很郁悶,試想是不是在哪個(gè)環(huán)節(jié)把VS2005組件勾上的?
    2011-02-02
  • MySQL磁盤碎片整理實(shí)例演示

    MySQL磁盤碎片整理實(shí)例演示

    這篇文章主要給大家介紹了關(guān)于MySQL磁盤碎片整理的相關(guān)資料,為什么數(shù)據(jù)庫(kù)會(huì)產(chǎn)生碎片,以及如何清理磁盤碎片,還有一些清理磁盤碎片的注意事項(xiàng),需要的朋友可以參考下
    2022-04-04
  • 詳解MySQL多表查詢

    詳解MySQL多表查詢

    最近學(xué)習(xí)了多表查詢,這篇文章主要給大家介紹了關(guān)于MySQL多表查詢,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下
    2023-04-04
  • MySQL怎么給字符串字段加索引

    MySQL怎么給字符串字段加索引

    本文主要介紹了MySQL怎么給字符串字段加索引,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • MySQL replace into 語(yǔ)句淺析(二)

    MySQL replace into 語(yǔ)句淺析(二)

    這篇文章主要介紹了MySQL replace into 語(yǔ)句淺析(二),本文著重給出了幾個(gè)特殊案例分析,需要的朋友可以參考下
    2015-05-05
  • linux下mysql數(shù)據(jù)庫(kù)單向同步配置方法分享

    linux下mysql數(shù)據(jù)庫(kù)單向同步配置方法分享

    mysql數(shù)據(jù)庫(kù)單向同步又叫做主從復(fù)制,是通過(guò)二進(jìn)制日志文件完成的,注意:mysql 數(shù)據(jù)庫(kù)的版本,兩個(gè)數(shù)據(jù)庫(kù)版本要相同
    2012-06-06
  • MySQL安裝后默認(rèn)自帶數(shù)據(jù)庫(kù)的作用詳解

    MySQL安裝后默認(rèn)自帶數(shù)據(jù)庫(kù)的作用詳解

    這篇文章主要介紹了MySQL安裝后默認(rèn)自帶數(shù)據(jù)庫(kù)的作用,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • Windows下mysql5.7.18安裝配置教程

    Windows下mysql5.7.18安裝配置教程

    這篇文章主要為大家詳細(xì)介紹了Windows下mysql5.7.18安裝配置教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07

最新評(píng)論