天天看点

MySql insert:当通过条件查询结果存在该条数据则不插入,否则执行insertMySql insert:当通过条件查询结果存在该条数据则不插入,否则执行insert

MySql insert:当通过条件查询结果存在该条数据则不插入,否则执行insert

eg:

INSERT INTO

user

(C_BH, C_NAME, C_SEX, C_IDCARD) SELECT

‘29789CF58816501E498C1678B224D111’,

‘小明’,

‘男’,

‘211111111101013x3x’

FROM

DUAL

WHERE

NOT EXISTS (

SELECT

C_BH,

C_NAME,

C_SEX,

C_IDCARD

FROM

user

WHERE

C_NAME = ‘小明’

AND C_IDCARD = ‘211111111101013x3x’

);

通过子查询判断是否存在,C_NAME = ‘小明’ 和C_IDCARD = ‘211111111101013x3x’的数据,不存在插入C_BH=’29789CF58816501E498C1678B224D111’ , C_NAME=’小明’ , C_SEX=’男’ , C_IDCARD=’211111111101013x3x’ , DUAL 为临时表,不需要创建,通过EXISTS检查子查询是否有数据返回(sql 返回结果集为真),NOT (sql 不返回结果集为真),如果子查询存在数据则不需要插入,否则插入

想要了解更多的mysql EXISTS 和 NOT EXISTS的用法可以看下这篇文章

http://www.cnblogs.com/glory-jzx/archive/2012/07/19/2599215.html

继续阅读