MySQL on duplicate key update用法

注意:坑

在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 )

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值