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