当前位置: 首页 > article >正文

Spring Boot的JdbcTemplate实现“不存在即插入,存在即更新”

在 Java 中实现【不存在即插入,存在即更新】 INSERT ... ON DUPLICATE KEY UPDATE

Spring BootJdbcTemplate 实现 INSERT ... ON DUPLICATE KEY UPDATE

如果你使用的是 Spring BootJdbcTemplate,可以这样实现:

代码示例
@Autowired
private JdbcTemplate jdbcTemplate;

public void upsertUserData(String userId, LocalDateTime dataTime, int field1, int field2, int field3) {
    String sql = "INSERT INTO table1 (user_id, data_time, field1, field2, field3) " +
                 "VALUES (?, ?, ?, ?, ?) " +
                 "ON DUPLICATE KEY UPDATE " +
                 "field1 = VALUES(field1), " +
                 "field2 = VALUES(field2), " +
                 "field3 = VALUES(field3)";
                 
    jdbcTemplate.update(sql, devId, dataTime, field1, field2, field3);
}
使用示例
upsertUserData("user_1", LocalDateTime.of(2024, 11, 18, 15, 0), 10, 20, 30);

在批量操作中实现

如果有多条数据需要同时插入或更新,可以使用 batchUpdate

@Autowired
private JdbcTemplate jdbcTemplate;

public void batchUpsert(List<Data> dataList) {
    String sql = "INSERT INTO table1 (dev_id, data_time, field1, field2, field3) " +
                 "VALUES (?, ?, ?, ?, ?) " +
                 "ON DUPLICATE KEY UPDATE " +
                 "field1 = VALUES(field1), " +
                 "field2 = VALUES(field2), " +
                 "field3 = VALUES(field3)";
    
    jdbcTemplate.batchUpdate(sql, dataList, dataList.size(), (ps, data) -> {
        ps.setString(1, data.getUserId());
        ps.setTimestamp(2, Timestamp.valueOf(data.getDataTime()));
        ps.setInt(3, data.getField1());
        ps.setInt(4, data.getField2());
        ps.setInt(5, data.getField3());
    });
}
数据模型
@Data
@AllArgsConstructor
public class Data {
    private String userId;
    private LocalDateTime dataTime;
    private int field1;
    private int field2;
    private int field3;
}
调用示例
List<Data> dataList = Arrays.asList(
    new Data("user_1", LocalDateTime.of(2024, 11, 18, 15, 0), 10, 20, 30),
    new Data("user_2", LocalDateTime.of(2024, 11, 18, 15, 15), 15, 25, 35)
);
batchUpsert(dataList);

注意事项

  1. 主键或唯一索引

    • 确保 user_iddata_time 组成的联合主键或唯一索引已正确设置,否则 ON DUPLICATE KEY UPDATE 无法生效。
    ALTER TABLE table1 ADD UNIQUE INDEX idx_unique_user_data (user_id, data_time);
    
  2. 字段更新逻辑

    • 如果部分字段不需要更新,可以省略对应字段的 ON DUPLICATE KEY UPDATE 语句。
  3. 性能优化

    • 对于大批量插入操作,可以考虑一次性提交多个记录,以减少网络和数据库连接开销。

这样,你就可以灵活地实现对 table1 表的插入和更新逻辑了!


http://www.kler.cn/a/413175.html

相关文章:

  • 第 37 章 - Go 语言 持续集成与持续部署
  • 鸿蒙学习使用本地真机运行应用/元服务 (开发篇)
  • 【算法 python A*算法的实现】
  • localStorage缓存 接口 配置
  • RNN模型文本预处理--数据增强方法
  • 【Linux庖丁解牛】—软件安装vim!
  • python学opencv|读取图像
  • 参加面试被问到的面试题
  • go语言里的mkdir mkdirall有什么区别?
  • mysql批量插入并忽略重复的数据
  • 缓存使用规范学习
  • A050-基于spring boot物流管理系统设计与实现
  • 代码美学3:RGB转化+MATLAB制作渐变色
  • nodejs import 导入module.exports = xxx的模块, 在ES6项目中导入commonJs规范的require模块
  • 物联网实验室建设方案
  • (长期更新)《零基础入门 ArcGIS(ArcMap) 》实验二----网络分析(超超超详细!!!)
  • 鸿蒙本地模拟器 模拟TCP服务端的过程
  • python简单算法
  • java全栈day10--后端Web基础(基础知识)
  • Nginx 架构与设计
  • 【计算机网络】多路转接之poll
  • 【rustdesk】客户端和服务端的安装和部署(自建服务器,docker,远程控制开源软件rustdesk)
  • Android开发简单mp4播放器
  • JAVA:Spring Boot 3 实现 Gzip 压缩优化的技术指南
  • 【计算机网络】Wireshark的小测试(Protocol Layers-Wireshark抓包与协议分析实验)
  • 构建Ceph分布式文件共享系统:手动部署指南