insert into `test_tab` (`name`,`age`) values ('zhangsan',24)
当前test_tab表的数据为:
name|age
:—-|:—
zhangsan|24
3.再执行一次步骤2的插入语句,则会报异常:
[Err] 1062 - Duplicate entry 'zhangsan' for key 'PRIMARY'
4.对步骤2的insert语句增加ignore关键字,则不会报异常,已存在的数据也不会被更新。
insert IGNORE into `test_tab` (`name`,`age`) values ('zhangsan',24) ;
------
语句执行情况:
受影响的行: 0
时间: 0.000s
当前test_tab表的数据为:
name|age
:—-|:—
zhangsan|24
不存在则插入,存在则更新,其一(使用DUPLICATE KEY UPDATE关键字)
在insert语句中使用ON DUPLICATE KEY UPDATE关键字实现数据不存在则插入,存在则更新的操作。判断数据重复的逻辑依然是主键冲突或者唯一键冲突。
官网上的相关介绍如下:
“
if you specify ON DUPLICATE KEY UPDATE, and a row is inserted that would cause a duplicate value in a UNIQUE index or PRIMARY KEY, an UPDATE of the old row is performed. The affected-rows value per row is 1 if the row is inserted as a new row, 2 if an existing row is updated, and 0 if an existing row is set to its current values.
”
Mysql官方文档中提供标准的语法:
INSERT
[INTO] tbl_name
[PARTITION (partition_name,...)]
[(col_name,...)]
{VALUES | VALUE} ({expr | DEFAULT},...),(...),...
[ ON DUPLICATE KEY UPDATE
col_name=expr
[, col_name=expr] ... ]
或者:
INSERT
[INTO] tbl_name
[PARTITION (partition_name,...)]
SET col_name={expr | DEFAULT}, ...
[ ON DUPLICATE KEY UPDATE
col_name=expr
[, col_name=expr] ... ]
或者:
INSERT
[INTO] tbl_name
[PARTITION (partition_name,...)]
[(col_name,...)]
SELECT ...
[ ON DUPLICATE KEY UPDATE
col_name=expr
[, col_name=expr] ... ]