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 )
相关推荐
Mr.Pascal3 小时前
Redis:主动更新,读时更新,定时任务。三种的优劣势对比
数据库·redis·缓存
思成不止于此4 小时前
【MySQL 零基础入门】DQL 核心语法(二):表条件查询与分组查询篇
android·数据库·笔记·学习·mysql
骥龙4 小时前
3.10、构建网络防线:防火墙、WAF 与蜜罐实战
服务器·网络·数据库·网络安全
帝吃藕和5 小时前
MySQL 知识点复习- 4. update/delete/like
mysql
gugugu.6 小时前
Redis 字符串类型完全指南:从原理到实战应用
数据库·redis·缓存
杨云龙UP6 小时前
MySQL 自动备份与覆盖恢复实战:一套脚本搞定全库/按库备份恢复
linux·运维·数据库·sql·mysql
workflower7 小时前
PostgreSQL 数据库优化
数据库·团队开发·数据库开发·时序数据库·数据库架构
计算机毕设VX:Fegn08958 小时前
计算机毕业设计|基于springboot + vue服装商城系统(源码+数据库+文档)
数据库·vue.js·spring boot·课程设计
WX-bisheyuange9 小时前
基于Spring Boot的智慧校园管理系统设计与实现
java·大数据·数据库·毕业设计
JavaGuide9 小时前
对标MinIO!全新一代分布式文件系统诞生!
数据库·后端