MySQL on duplicate key update用法

基本使用方法

java 复制代码
public static final String SQL_TQI_SINK =
            "insert into " + ConfigureContext.get(ConfigKeyConstants.MYSQL_TABLE_TQI) + " \n" +
                    "(`mile_km`, `mile_start_km`, `mile_start_m`, `is_out`, `tqi_alig_l`, \n" +
                    "`tqi_alig_r`, `tqi_surf_l`, `tqi_surf_r`, `tqi_lev`, `tqi_gaug`, `tqi_twis`, `tqi_sum`, \n" +
                    "`out_value`, `average_speed`, `tran_cd`, `sped_cd`, `valid_flag`, `valid`, `dete_ymd`, \n" +
                    "`dete_hms`, `sub_code`, `line_cd`, `line_nm`, `dir_cd`, `dir_nm`, `regi_dt`)\n" +
                    "values (?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?)\n" +
                    "on duplicate key update \n" +
                    "mile_km = values(mile_km), \n" +
                    "mile_start_km = values(mile_start_km), \n" +
                    "mile_start_m = values(mile_start_m), \n" +
                    "is_out = values(is_out), \n" +
                    "tqi_alig_l = values(tqi_alig_l), \n" +
                    "tqi_alig_r = values(tqi_alig_r), \n" +
                    "tqi_surf_l = values(tqi_surf_l), \n" +
                    "tqi_surf_r = values(tqi_surf_r), \n" +
                    "tqi_lev = values(tqi_lev), \n" +
                    "tqi_gaug = values(tqi_gaug), \n" +
                    "tqi_twis = values(tqi_twis), \n" +
                    "tqi_sum = values(tqi_sum), \n" +
                    "out_value = values(out_value), \n" +
                    "average_speed = values(average_speed), \n" +
                    "tran_cd = values(tran_cd), \n" +
                    "sped_cd = values(sped_cd), \n" +
                    "valid_flag = values(valid_flag), \n" +
                    "valid = values(valid), \n" +
                    "dete_ymd = values(dete_ymd), \n" +
                    "dete_hms = values(dete_hms), \n" +
                    "sub_code = values(sub_code), \n" +
                    "line_cd = values(line_cd), \n" +
                    "line_nm = values(line_nm), \n" +
                    "dir_cd = values(dir_cd), \n" +
                    "dir_nm = values(dir_nm)";

如果数据库有值,不想覆盖数据库的值,可以采用以下写法

mysql(ON DUPLICATE KEY UPDATE)字段值为空更新新值,不为空不更新

tableName: 表名

id: 主键(唯一键)

field_1: 更新的字段

原值为空更新

sql 复制代码
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 ) )

新值大于旧值更新

sql 复制代码
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 )
相关推荐
QQ_4376643141 小时前
Redis协议与异步方式
数据库·redis·bootstrap
纪莫1 小时前
技术面:MySQL篇(InnoDB事务执行过程、事务隔离级别、事务并发异常)
数据库·java面试⑧股
Nerd Nirvana1 小时前
数据库模型全景:从原理到实践的系统性指南
数据库·oracle·电力行业
SelectDB1 小时前
从 Greenplum 到 Doris:集群缩减 2/3、年省数百万,度小满构建超大规模数据分析平台经验
数据库·数据分析·apache
alonewolf_992 小时前
MySQL索引优化实战二:分页、关联查询与Count优化深度解析
数据库·mysql
TDengine (老段)2 小时前
TDengine Python 连接器进阶指南
大数据·数据库·python·物联网·时序数据库·tdengine·涛思数据
赵渝强老师2 小时前
【赵渝强老师】OceanBase的配置文件与配置项
数据库·oceanbase
玖日大大3 小时前
OceanBase SeekDB:AI 原生数据库的技术革命与实践指南
数据库·人工智能·oceanbase
高溪流4 小时前
3.数据库表的基本操作
数据库·mysql
alonewolf_994 小时前
深入剖析MySQL锁机制与MVCC原理:高并发场景下的数据库核心优化
数据库·mysql