2

我有两个不同的数据库 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
4

1 回答 1

2

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 的数据库有额外的列,那么这个查询将不会识别。您最好在数据集之间实现完全外连接。

于 2013-09-09T11:06:30.823 回答