INSERT INTO ON DUPLICATE KEY UPDATE 与 REPLACE INTO,两个命令可以处理重复键值问题,在实际上它之间有什么区别呢?前提条件是这个表必须有一个唯一索引或主键. 1.REPLACE发现重复的先删除再插入,如果记录有多个字段,在插入的时候如果有的字段没有赋值,那么新插入的记录这些字段为空.2.INSERT发现重复的是更新操作.在原有记录基础上,更新指定字段内容,其它字段内容保留. 这样REPLACE的操作成本要大于 insert ON DUPLICATE…
#下面建立game表,设置name值为唯一索引. CREATE TABLE `game` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(20) CHARACTER SET utf8 NOT NULL, `type_id` tinyint(4) NOT NULL DEFAULT '0', `attr` varchar(20) NOT NULL, `type_extends` varchar(20) NOT NULL, PRIMARY…
前提条件:必须是唯一主键: CREATE UNIQUE INDEX idx_vote_object ON test_customers_vote (`vote_object`, `vote_object_id`); 用一条sql实现“不存在即插入,存在则increase 某字段”的复合功能 – insert into … on duplicate key update比如:CREATE UNIQUE INDEX comp ON logs (`site_id`, `time`); INSERT I…