我有两个不同的数据库 Miadb 和 DWH。我想比较不同数据库中两个表的列定义。
我写了这个 SQL,但它不起作用:
SELECT * FROM USER_TAB_COLUMNS WHERE TABLE_NAME='ibrmt030@miadb'
minus
SELECT * FROM USER_TAB_COLUMNS WHERE TABLE_NAME='ibrmt030@dwh';
错误消息是:
ORA-00997: geçersiz LONG veri türü kullanımı
00997. 00000 - "illegal use of LONG datatype"
Cause:
*Action:
Error at Line: 1 Column: 8
最佳答案
USER_TAB_COLUMNS 不包含其他数据库中表的条目。
这可能会起作用:
SELECT * FROM USER_TAB_COLUMNS@miadb WHERE TABLE_NAME='IBRMT030'
minus
SELECT * FROM USER_TAB_COLUMNS@dwh WHERE TABLE_NAME='IBRMT030';
其中有许多元数据列可能会导致系统之间的行不匹配(其中之一可能是 LONG 数据类型,这会导致该错误)。将您的查询限制为仅必需的列。
顺便说一句,如果 DWH 的数据库有额外的列,则此查询中不会识别出这些列。您最好在数据集之间实现完整的外部联接。
关于oracle - 比较 Oracle 数据库之间的列定义,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18696615/