首页 >数据库 >mysql教程 >如何高效更新数据库表1.2亿条记录?

如何高效更新数据库表1.2亿条记录?

DDD
DDD原创
2024-12-31 17:57:10735浏览

How Can I Efficiently Update 120 Million Records in a Database Table?

优化海量记录更新操作

问题:
使用即使运行了多次,简单的 UPDATE 语句也失败了

解决方案:

不要更新现有表,而是使用 SELECT 语句用所需的值填充新表。这种方法显着提高了性能并避免了与直接更新相关的瓶颈。

非简单情况的步骤:

  1. 创建一个具有所需的新表结构:

    • 使用相同的聚集索引、标识列、计算列和要更新的新列在不同架构下重新创建原始表。
    • 排除触发器、外键约束和其他非必要的
  2. 测试插入操作:

    • 将一小部分行插入新表中以确保正确性。
  3. 准备批量插入:

    • 将数据库设置为批量日志或简单恢复模式。
    • 截断新的
  4. 执行批量插入:

    • 使用带有 TABLOCK 的单个 INSERT 语句提示。
  5. 验证数据完整性:

    • 检查新表以确认更新成功。
  6. 重新创建约束和触发器:

    • 在新表中重新创建所有非聚集约束、索引和触发器,同时在单独的批次中维护架构。
  7. 切换表:

    • 将原始表移至备份架构,并将新表移至所需架构。
    • 执行任何必要的调整操作以协调发生的任何更改更新过程中。

以上是如何高效更新数据库表1.2亿条记录?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn