SQL中replace用法

在 SQL 中,REPLACE INTO 语句的作用是先尝试插入一条新记录。如果插入的记录与表中已有的记录(根据主键或唯一索引进行匹配)有冲突,则会删除冲突的记录,并用新的记录替换掉它。

换句话说,REPLACE INTO 可以防止重复插入相同的记录。它的作用类似于先删除再插入,从而确保每次插入的记录是唯一的。

新增示例:

xml 复制代码
    <insert id="insertTest">
        replace into test_user (id, name, manager_id, salary, age, depart_id, remark, province, content)
        values
        (#{id}, #{name}, #{managerId}, #{salary}, #{age}, #{departId}, #{remark}, #{province}, #{content})
    </insert>

从上面操作可以看出:

第一次:id = 3 的记录不存在,直接插入新记录。Updates: 1

第二次:id = 3 的记录已经存在,它将被删除并用新插入的记录替换。Updates: 2

注意事项:

  1. REPLACE INTO 依赖于表的 主键 或 唯一索引 来判断是否已有重复记录。
  2. 如果存在重复的记录,它会删除并插入新记录,这可能会导致删除和重新插入的性能开销。
  3. 它不会简单地忽略重复记录,而是会删除旧记录再插入新的记录。
相关推荐
皮皮林55114 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河14 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
桦说编程17 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅18 小时前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者19 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺19 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
倔强的石头_20 小时前
kingbase备份与恢复实战(二)—— sys_dump库级逻辑备份与恢复(Windows详细步骤)
数据库
Derek_Smart21 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP1 天前
MyBatis-mybatis入门与增删改查
java