MySql 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

你可能感兴趣的:(MySql)