深入理解和优雅使用ON DUPLICATE KEY Update 解决存在则更新,不存在则新增的问题
先看语法INSERT INTO table(id,a,……) values(1,‘xh’,……) ON DUPLICATE KEY Update a=‘value’,……;
举个例子
1,先创建表结构如下
DROP TABLE IF EXISTS `t_ware_duplicate`;
CREATE TABLE `t_ware_duplicate` (
`id` int(11) NOT N
mysql “ON DUPLICATE KEY UPDATE” 语法如果在INSERT语句末尾指定了ON DUPLICATE KEY UPDATE,并且插入行后会导致在一个UNIQUE索引或PRIMARY KEY中出现重复值,则在出现重复值的行执行UPDATE;如果不会导致唯一值列重复的问题,则插入新行。 例如,如果列 a 为 主键 或 拥有UNIQUE索引,并且包含值1,则以下两个语句具有相同的效果: 代码如下:INSERT INTO TABLE (a,c) VALUES (1,3) ON D