注意:坑
在ON DUPLICATE KEY UPDATE后面不要写主键,和唯一索引的列,要不然会报错
如果还报错,检查ON DUPLICATE KEY UPDATE后面写的字段,如果有not null定义的字段,把not null改成default null
如果还报错,检查是否有其他的索引
基本使用方法
public static final String SQL_SINK =
"insert into " + ConfigureContext.get(ConfigKeyConstants.MYSQL_TABLE) + " \n" +
"(`id`, `name`)\n" +
"values (?, ?)\n" +
"on duplicate key update \n" +
"name = values(name) \n"
;
如果数据库有值,不想覆盖数据库的值,可以采用以下写法
public static final String SQL_SINK =
"insert into " + ConfigureContext.get(ConfigKeyConstants.MYSQL_TABLE) + " \n" +
"(`id`, `name`)\n" +
"values (?, ?)\n" +
"on duplicate key update \n" +
"name = if(MYSQL_TABLE.name, MYSQL_TABLE.name, values(name)) \n"
;
mysql(ON DUPLICATE KEY UPDATE)字段值为空更新新值,不为空不更新
tableName: 表名
id: 主键(唯一键)
field_1: 更新的字段
原值为空更新
INSERT IGNORE INTO `tableName` ( `id`, `field_1` )
VALUES
( '1', '100' ),
( '2', '200' )
ON DUPLICATE KEY UPDATE field_1 =
IF
( tableName.field_1, tableName.field_1, VALUES ( field_1 ) )
新值大于旧值更新
INSERT IGNORE INTO `tableName` ( `id`, `field_1` )
VALUES
( '1', '100' ),
( '2', '200' )
ON DUPLICATE KEY UPDATE field_1 =
IF
( VALUES ( field ) > tableName.field_1, VALUES ( field_1 ), tableName.field_1 )