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. 它不会简单地忽略重复记录,而是会删除旧记录再插入新的记录。
相关推荐
倔强的石头_11 小时前
《Kingbase护城河》——猎捕慢查询:执行计划的微观解析与索引调优实战
数据库
SelectDB13 小时前
Apache Doris Python UDF:让 SQL 直接调用 Python 生态,支撑 Agent 时代复杂业务逻辑
大数据·数据库·python
Flittly14 小时前
【AgentScope Java新手村系列】(16)从RAG到多路检索
java·spring boot·spring
小兔崽子去哪了14 小时前
Java 生成二维码解决方案
java·后端
人活一口气19 小时前
从JVM调优到MCP协议:Java全栈技术体系深度总结与企业级架构实践
java·spring boot
NE_STOP21 小时前
Vibe Coding -- 完整项目案例实操
java
荣码21 小时前
GraphRAG:普通RAG只能回答"点"的问题,我踩了4个坑才搞懂
java·python
SimonKing21 小时前
Google第三方授权登录
java·后端·程序员
明月光81821 小时前
从一行 @Builder 说起:重新拾起 Java 的 Lombok、注解与 Builder 模式
java
考虑考虑1 天前
Mybatis实现批量插入
java·后端·mybatis