天天看點

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

繼續閱讀