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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL的INSERT INTO··· ON DUPLICATE KEY UPDATE使用的几种情况

發(fā)布時(shí)間:2025/3/12 数据库 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL的INSERT INTO··· ON DUPLICATE KEY UPDATE使用的几种情况 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

保存或更新

在MySQL數(shù)據(jù)庫中,如果在insert語句后面帶上ON DUPLICATE KEY UPDATE 子句,而要插入的行與表中現(xiàn)有記錄的惟一索引或主鍵中產(chǎn)生重復(fù)值,那么就會(huì)發(fā)生舊行的更新;如果插入的行數(shù)據(jù)與現(xiàn)有表中記錄的唯一索引或者主鍵不重復(fù),則執(zhí)行新紀(jì)錄插入操作。另外,ON DUPLICATE KEY UPDATE不能寫where條件。

示例:

create table kid_score( id tinyint unsigned not null, birth_day date not null, score int unsigned not null, primary key(id, birth_day) --唯一索引是由 id + birth_day 兩個(gè)字段組成 ) engine = InnoDB;--初始化數(shù)據(jù) insert into kid_score(id, birth_day, score) values (1,'2019-01-15',10),(2,'2019-01-16',20);

下面開始驗(yàn)證執(zhí)行INSERT ··· ON DUPLICATE KEY UPDATE語法的規(guī)則:如果你插入的記錄導(dǎo)致一個(gè)UNIQUE索引或者primary key(主鍵)出現(xiàn)重復(fù),那么就會(huì)認(rèn)為該條記錄存在,則執(zhí)行update語句而不是insert語句,反之,則執(zhí)行insert語句而不是更新語句。

1. 唯一索引重復(fù)

insert into kid_score(id, birth_day, score) values (1,'2019-01-15',30) ON DUPLICATE KEY UPDATE score = score + 50;

結(jié)果:

2. 唯一索引不重復(fù)

insert into kid_score(id, birth_day, score) values (2,'2019-01-15',30) ON DUPLICATE KEY UPDATE score = score + 50;

結(jié)果:

3. 唯一索引重復(fù),插入完全相同數(shù)據(jù)

insert into kid_score(id, birth_day, score) values (2,'2019-01-16',20) ON DUPLICATE KEY UPDATE score = 20;

結(jié)果:

4. 影響行數(shù)

需要注意的是:如果行作為新記錄被插入,則受影響行的值為1;如果原有的記錄被更新,則受影響行的值為2,如果更新的數(shù)據(jù)和已有的數(shù)據(jù)一模一樣,則受影響的行數(shù)是0。

mysql> select * from kid_score; +----+------------+-------+ | id | birth_day | score | +----+------------+-------+ | 1 | 2019-01-15 | 10 | | 2 | 2019-01-16 | 20 | +----+------------+-------+ 2 rows in set-- 唯一索引重復(fù),執(zhí)行更新 mysql> insert into kid_score(id, birth_day, score) values (1,'2019-01-15',30) ON DUPLICATE KEY UPDATE score = score + 50; Query OK, 2 rows affectedmysql> select * from kid_score; +----+------------+-------+ | id | birth_day | score | +----+------------+-------+ | 1 | 2019-01-15 | 60 | | 2 | 2019-01-16 | 20 | +----+------------+-------+ 2 rows in set-- 唯一索引不重復(fù),執(zhí)行插入 mysql> insert into kid_score(id, birth_day, score) values (2,'2019-01-15',30) ON DUPLICATE KEY UPDATE score = score + 50;Query OK, 1 row affectedmysql> select * from kid_score; +----+------------+-------+ | id | birth_day | score | +----+------------+-------+ | 1 | 2019-01-15 | 60 | | 2 | 2019-01-15 | 30 | | 2 | 2019-01-16 | 20 | +----+------------+-------+ 3 rows in set-- 唯一索引重復(fù),應(yīng)該執(zhí)行更新,但更新值與原值相同 mysql> insert into kid_score(id, birth_day, score) values (2,'2019-01-16',20) ON DUPLICATE KEY UPDATE score = 20;Query OK, 0 rows affectedmysql> select * from kid_score; +----+------------+-------+ | id | birth_day | score | +----+------------+-------+ | 1 | 2019-01-15 | 60 | | 2 | 2019-01-15 | 30 | | 2 | 2019-01-16 | 20 | +----+------------+-------+ 3 rows in set

總結(jié)

以上是生活随笔為你收集整理的MySQL的INSERT INTO··· ON DUPLICATE KEY UPDATE使用的几种情况的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

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