replace的运行与insert很相似。只有一点例外,假如表中的一个旧记录与一个用于primary key或一个unique索引的新记录具有相同的值,则在新记录被插入之前,旧记录被删除。
注意,除非表有一个primary key或unique索引,否则,使用一个replace语句没有意义。该语句会与insert相同,因为没有索引被用于确定是否新行复制了其它的行。
下面是replace into的一个坑:
http://blog.xupeng.me/2013/10/11/mysql-replace-into-trap/
