MySQL 记录不存在插入 和 存在则更新

1. 不存在则插入,存在则不插入

想要插入一条数据,要避免重复插入,又不想折腾两回数据库连接操作,可以参考如下办法

语法: 此处 aa,bb,cc 为要插入的 a,b,c 列的值

INSERT INTO table1 (a,b,c) SELECT aa,bb,cc from dual where not exists (SELECT
		c
	FROM
		table1
	where 
a = 18 and b =133)

示例:
插入 situation_alert ,situation_id= 18 ,alert_id=133,create_time=now() ,当该条记录不存在则插入。

insert into situation_alert (situation_id,alert_id,create_time) SELECT 18,133,now() from dual where
  not exists (SELECT
		alert_id
	FROM
		situation_alert
	where 
situation_id = 18 and alert_id =133);

2. 不存在则插入,存在则更新(推荐)

插入一条数据,如果该数据存在则更新原有数据,如果不存在则插入。
注意:此处表应该有唯一值索引,因为DUPLICATE KEY UPDATE 是通过唯一值索引来判断记录是否存在
并且 DUPLICATE KEY UPDATE 支持批量插入。

// 存在则更新UPDATE 后的 列的值,比如存在唯一值则更新 列c 的值为 c+1
INSERT INTO table (a,b,c) VALUES (1,2,3)
  ON DUPLICATE KEY UPDATE c=c+1;

INSERT 中 ON DUPLICATE KEY UPDATE的使用

如果指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则执行旧行UPDATE。例如,如果列a被定义为UNIQUE,并且包含值1,则以下两个语句具有相同的效果:

mysql> INSERT INTO table (a,b,c) VALUES (1,2,3) ON DUPLICATE KEY UPDATE c=c+1; 
mysql> UPDATE table SET c=c+1 WHERE a=1; 

注意:UPDATE c=c+1;  没有set 语句哦

如果行作为新记录被插入,则受影响行的值为1;如果原有的记录被更新,则受影响行的值为2。

注释:如果列b也是唯一列,则INSERT与此UPDATE语句相当:

 UPDATE table SET c=c+1 WHERE a=1 OR b=2 LIMIT 1; 

如果a=1 OR b=2与多个行向匹配,则只有一个行被更新。通常,您应该 尽量避免对带有多个唯一关键字的表使用ON DUPLICATE KEY子句。

可以在UPDATE子句中使用VALUES(col_name)函数从INSERT…UPDATE语句的INSERT部分引用列值。

换句话说,如果没有发生重复关键字冲突,则UPDATE子句中的VALUES(col_name)可以引用被插入的col_name的值。本函数特别适用于多行插入。,重复时更新多列则使用逗号隔开
VALUES()函数只在INSERT…UPDATE语句中有意义,其它时候会返回NULL。

示例:


INSERT INTO table (a,b,c)  VALUES (1,2,3),(4,5,6)  ON DUPLICATE KEY UPDATE c=VALUES(a)+VALUES(b), a=VALUES(a),b=VALUES(b); 

本语句与以下两个语句作用相同:


mysql> INSERT INTO table (a,b,c) VALUES (1,2,3) 
         -> ON DUPLICATE KEY UPDATE c=3; 
mysql> INSERT INTO table (a,b,c) VALUES (4,5,6) 
         -> ON DUPLICATE KEY UPDATE c=9;  
INSERT ... SELECT

INSERT ... ON DUPLICATE KEY UPDATE

INSERT ... ON DUPLICATE REPLACE

亲测有效;
参考:http://www.cnblogs.com/emanlee/p/3854812.html

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值