Replace into
replace into 跟 insert 功能類似,
不同點在于:replace into 首先嘗試插入數據到表中,
1. 如果發現表中已經有此行數據(根據主鍵或者唯一索引判斷)則先刪除此行數據,然后插入新的數據。
2. 否則,直接插入新數據。
要注意的是:插入數據的表必須有主鍵或者是唯一索引!否則的話,replace into 會直接插入數據,這將導致表中出現重復的數據。
replace into 有三種形式:
replace into tbl_name(col_name, ...) values(...)
replace into tbl_name(col_name, ...) select ...
replace into tbl_name set col_name=value, ...
前兩種形式用的多些。其中 “into” 關鍵字可以省略,不過最好加上 “into”,這樣意思更加直觀。另外,對于那些沒有給予值的列,MySQL 將自動為這些列賦上默認值。
Insert update
INSERT 中 ON DUPLICATE KEY UPDATE的使用
如果您指定了ON DUPLICATE KEY UPDATE,并且insert行后會導致在一個UNIQUE索引或PRIMARY KEY中出現重復值,則執行舊行UPDATE。例如,如果列a被定義為UNIQUE,并且包含值1,則以下兩個語句具有相同的效果:
mysql> INSERT INTO table (a,b,c) VALUES (1,2,3)? ON DUPLICATE KEY UPDATE c=c+1;
mysql> UPDATE table SET c=c+1 WHERE a=1;
總之
如果表中不存在主鍵記錄,replace和insert*update都與insert是一樣的特點。
如果表中存在主鍵記錄,replace相當于執行delete 和 insert兩條操作,而insert*update的相當于執行if exist do update else do insert操作。
因此,如果replace填充的字段不全,則會導致未被更新的字段都會修改為默認值,并且如果有自增id的話,自增id會變化為最新的值(這樣如果是以自增id為標志的話可能導致記錄丟失);而insert*update只是更新部分字段,對于未被更新的字段不會變化(不會強制修改為默認值)。
例子:
INSERT INTO FDM_LOG_RECORD(LOG_ID) VALUES('1426683600001') ON DUPLICATE KEY UPDATE RETRY_TIME = RETRY_TIME + 1, STATUS = 0
注意,以上語句在springjdbc中使用,即便是沒有,也會執行后面的語句