mysql insert into on duplicate key update_mysql 中 replace into 与 insert into on duplicate key update...

本文实例讲述了mysql 中 replace into 与 insert into on duplicate key update 的用法和不同点。分享给大家供大家参考,具体如下:

replace into和insert into on duplicate key update都是为了解决我们平时的一个问题

就是如果数据库中存在了该条记录,就更新记录中的数据,没有,则添加记录。

我们创建一个测试表test

CREATE TABLE `test` (

`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',

`name` varchar(32) DEFAULT '' COMMENT '姓名',

`addr` varchar(256) DEFAULT '' COMMENT '地址',

PRIMARY KEY (`id`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

向该表中插入一些数据

INSERT INTO test

VALUES

(NULL, 'a', 'aaa'),

(NULL, 'b', 'bbb'),

(NULL, 'c', 'ccc'),

(NULL, 'd', 'ddd');

影响行数4,结果如下:

e8d2b933329a0c09e674d8d9f8af75fc.png

我们运行如下语句:

REPLACE INTO test VALUES(NULL, 'e', 'eee');

结果显示,影响行数1条,记录被插入成功了

227c467abf307988707b6a00e364cb30.png

注意上面的语句,我们并没有填写主键ID。

然后我们再执行下面的语句:

REPLACE INTO test VALUES(1, 'aa', 'aaaa');

结果显示,影响行数2条,ID为1的记录被更新成功了

f8bcb6bbbb060cc15547cf263568d776.png

为什么会出现这种情况,原因就是replace into会首先尝试先往表里面插入记录,因为我们的ID是主键,不可重复,显然这条记录是无法插入成功的,然后replace into会把这条已存在的记录删掉,然后再插入,所以会显示影响行数是2。

我们再运行下面这条语句:

REPLACE INTO test(id,name) VALUES(1, 'aaa');

这里我们只指定id,name字段,我们来看看replace into后addr字段内容是否还存在

4f33c7394482c06f08eec369f944fad8.png

显然addr字段内容没有了,跟我们上面的分析是一致的,reaplce into先删除了id为1的记录,然后再插入记录,但我们并没有指定addr的值,所以会如上图所示那样。

但是有些时候我们的需求是,如果记录存在则更新指定字段的数据,原有字段数据仍保留,而不是上面所示的,addr字段数据没有了。

这里就需要用到insert into on duplicate key update

执行如下语句:

INSERT INTO test (id, name)

VALUES(2, 'bb')

ON DUPLICATE KEY

UPDATE

name = VALUES(name);

VALUES(字段名)表示获取当前语句insert的列值,VALUES(name)表示的就是'bb'

结果显示,影响行数2条

29cec32298bf3506a442a5bcc77e2e55.png

如上图所示,addr字段的值被保留了。

insert into on duplicate key update语句的做法是先插入记录,如果不成功,则更新记录,但是为什么影响的行数是2?

我们重新建一张表test2

CREATE TABLE `test2` (

`id` int(11) unsigned NOT NULL AUTO_INCREMENT COMMENT 'ID',

`sn` varchar(32) DEFAULT '' COMMENT '唯一键',

`name` varchar(32) DEFAULT '' COMMENT '姓名',

`addr` varchar(256) DEFAULT '' COMMENT '地址',

PRIMARY KEY (`id`),

UNIQUE KEY `sn` (`sn`)

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

往里面插入点数据

INSERT INTO test2

VALUES

(NULL, '01', 'a', 'aaa'),

(NULL, '02', 'b', 'bbb'),

(NULL, '03', 'c', 'ccc'),

(NULL, '04', 'd', 'ddd');

我们运行如下语句:

INSERT INTO test2 (sn, name, addr)

VALUES

('02', 'bb', 'bbbb')

ON DUPLICATE KEY

UPDATE

name = VALUES(name),

addr = VALUES(addr);

结果如下:

81bb4b8d23496856fd5a3eefda54d32c.png

每运行一次上面的语句,虽然影响行数为0,但表test2的自增字段就加1。

925d159b4a22ffb35967c797cd9aeb38.png

显然如果insert into on duplicate key update语句仅仅只是在原记录基础上进行更新操作的话,自增字段是不会自动加1的,说明它也进行了记录删除操作。

先插入记录,如果不成功,则删除原记录,但保留了除update语句后字段的值,然后把保留的值与需要更新的值合并,然后插入一条新记录。

总结:

replace into 与 insert into on duplicate key update都是先尝试插入记录,如果不成功,则删除记录,replace into不保留原记录的值,而insert into on duplicate key update保留。然后插入一条新记录。

希望本文所述对大家MySQL数据库计有所帮助。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值