首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >比较Oracle数据库之间的列定义

比较Oracle数据库之间的列定义
EN

Stack Overflow用户
提问于 2013-09-09 18:53:28
回答 1查看 547关注 0票数 2

我有两个不同的数据库Miadb和DWH。我想比较不同数据库中两个表的列定义。

我写了这个SQL,但它不能工作:

代码语言:javascript
复制
SELECT * FROM USER_TAB_COLUMNS WHERE TABLE_NAME='ibrmt030@miadb' 
minus
SELECT * FROM USER_TAB_COLUMNS WHERE TABLE_NAME='ibrmt030@dwh';

错误-消息为:

代码语言:javascript
复制
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
EN

回答 1

Stack Overflow用户

发布于 2013-09-09 19:06:31

USER_TAB_COLUMNS不包含其他数据库中表的条目。

这可能会起作用:

代码语言:javascript
复制
SELECT * FROM USER_TAB_COLUMNS@miadb WHERE TABLE_NAME='IBRMT030' 
minus
SELECT * FROM USER_TAB_COLUMNS@dwh WHERE TABLE_NAME='IBRMT030';

其中有许多元数据列可能会导致系统之间的行不匹配(其中一个可能是LONG数据类型,这就是导致该错误的原因)。将您的查询限制为仅基本列。

顺便说一句,如果DWH上的数据库有额外的列,那么在这个查询中就不会识别出这个列。你最好在数据集之间实现一个完整的外连接。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18696615

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档