gpt4 book ai didi

Oracle DBMS 打包命令将表内容导出为 INSERT 语句

转载 作者:搜寻专家 更新时间:2023-10-30 19:41:57 25 4
gpt4 key购买 nike

有没有类似于DBMS_METADATA.GET_DDL的子程序可以将表数据导出为INSERT语句?

例如,使用 DBMS_METADATA.GET_DDL('TABLE', 'MYTABLE', 'MYOWNER') 将为 MYOWNER.MYTABLE 导出 CREATE TABLE 脚本。任何类似的东西都可以从 MYOWNER.MYTABLE 生成所有数据作为 INSERT 语句?

我知道例如 TOAD Oracle 或 SQL Developer 可以非常快地导出为 INSERT 语句,但我需要一种更编程的方式来完成它。此外,我无法在我正在使用的数据库中创建任何过程或函数。

谢谢。

最佳答案

据我所知,没有 Oracle 提供的包可以执行此操作。我会怀疑任何声称可以实现此目标的第 3 方工具,因为这基本上是不可能的。

我曾经写过这样的包,很快就后悔了。获得在 99% 的时间都有效的东西很容易,但最后的 1% 会要了你的命。

如果你真的需要这样的东西,并且需要它非常准确,你必须严格控制允许哪些数据以及可以使用哪些工具来运行脚本。以下是您将面临的一小部分问题:

  • 逃避
  • 单次插入非常慢(尤其是通过网络时)
  • 组合插入速度更快,但当您开始插入数百行时可能会遇到一些讨厌的解析错误
  • 有许多潜在的数据类型,包括自定义数据类型。您现在可能只有 NUMBER、VARCHAR2 和 DATE,但是如果有人添加 RAW、BLOB、BFILE、嵌套表等会怎样?
  • 由于 VARCHAR2 大小限制(4000 或 32767,取决于您的操作方式),存储 LOB 需要将数据分成 block 。
  • 字符集问题 - 这会让您发疯。
  • 环境限制 - 例如,SQL*Plus 不允许每行超过 2500 个字符,并且会在行尾删除空格。
  • 参照完整性 - 您需要禁用这些约束或以正确的顺序插入数据。
  • “假”列 - 虚拟列、XML lob 等 - 不要导入这些。
  • 缺少分区 - 如果您没有使用 INTERVAL 分区,您可能需要手动创建它们。
  • 新数据 - 几乎任何约束都可能被违反,因此您可能需要禁用所有内容。

如果您希望数据准确,您只需使用 Oracle 实用程序,例如数据泵和导出。

关于Oracle DBMS 打包命令将表内容导出为 INSERT 语句,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8357226/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com