浅析MySQL replace into 的用法
在SQLServer中可以这样处理:
ifnotexists(select1fromtwhereid=1) insertintot(id,update_time)values(1,getdate()) else updatetsetupdate_time=getdate()whereid=1
那么MySQL中如何实现这样的逻辑呢?别着急!MySQL中有更简单的方法:replaceinto
replaceintot(id,update_time)values(1,now()); 或 replaceintot(id,update_time)select1,now();
replaceinto跟insert功能类似,不同点在于:replaceinto首先尝试插入数据到表中,1.如果发现表中已经有此行数据(根据主键或者唯一索引判断)则先删除此行数据,然后插入新的数据。2.否则,直接插入新数据。要注意的是:插入数据的表必须有主键或者是唯一索引!否则的话,replaceinto会直接插入数据,这将导致表中出现重复的数据。
MySQLreplaceinto有三种形式:
replaceintotbl_name(col_name,...)values(...) replaceintotbl_name(col_name,...)select... replaceintotbl_namesetcol_name=value,...
前两种形式用的多些。其中“into”关键字可以省略,不过最好加上“into”,这样意思更加直观。另外,对于那些没有给予值的列,MySQL将自动为这些列赋上默认值。