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

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值