使用replace一個語句可以完成上面兩個語句的功能,其語法與insert差不多.如上面的操作可以寫為replace into t_test set ikey=1,value='a',icount=0;則表中有ikey為1時,先刪除舊數據.然后插入新數據.否則直接插入數據.
(2) key存在則更新,不存在則插入
insert into .... on duplicate key update
對于需要根據原記錄進行操作的.如表中icount字段用于計數,當沒有記錄時,插入的value為0,當有記錄時,value需要更新為value+1,這時replace就不能完成這個功能.使用insert則可以,其基本語法是insert into ... on duplicate key update...,如上述語句為
insert into t_test set ikey=1,value='a',value2=1 on duplicate key update value2=value2+1;
則replace into t_test set ikey=1,value='a',icount=0;會把表中的兩條記錄都刪除,然后插入新記錄.
而insert into t_test set ikey=1,value='a',icount=0 on duplicate key update icount=icount+1則只更新一條記錄.其效果相當于update t_test set icount=icount+1 where ikey=1 or value='a' limit 1;
您可能感興趣的文章:
mysql 存在該記錄則更新,不存在則插入記錄的sqlmysql 記錄不存在時插入 記錄存在則更新的實現方法SQL Server并發處理存在就更新解決方案探討