有时候会有某种需求:需要对比两个表的表结构是否一致,有时候甚至是整个数据库所有表的表结构对比......。表结构对比无非就是字段名、字段类型、字段数据类型、以及字段的顺序的对比。如果需要对比表结构,可以通过下面简单的脚本实现:

SELECT M.OWNER

      ,M.TABLE_NAME

      ,M.COLUMN_ID

      ,M.COLUMN_NAME

      ,M.DATA_TYPE

      ,M.DATA_LENGTH

      ,N.OWNER

      ,N.TABLE_NAME

      ,N.COLUMN_ID

      ,N.COLUMN_NAME

      ,N.DATA_TYPE

      ,N.DATA_LENGTH

FROM

(

SELECT OWNER

      ,TABLE_NAME

      ,COLUMN_ID

      ,COLUMN_NAME

      ,DATA_TYPE

      ,DATA_LENGTH

FROM DBA_TAB_COLUMNS

WHERE OWNER=&OWNER_A

  AND TABLE_NAME=&TABLE_NAME_A

) M LEFT JOIN

(

SELECT OWNER

      ,TABLE_NAME

      ,COLUMN_ID

      ,COLUMN_NAME

      ,DATA_TYPE

      ,DATA_LENGTH

FROM DBA_TAB_COLUMNS

WHERE OWNER=&OWNER_B

  AND TABLE_NAME=&TABLE_NAME_B

) N ON  M.COLUMN_ID =N.COLUMN_ID

    AND M.COLUMN_NAME = N.COLUMN_NAME 

    AND M.DATA_TYPE = N.DATA_TYPE 

    AND M.DATA_LENGTH= N.DATA_LENGTH

ORDER BY M.TABLE_NAME, M.COLUMN_ID;

但是如果A表与B表前面的字段一致,然而B表有一些额外的字段,那么上面的SQL(左连接)就会查不出两者之间结构的不同。此时需要使用右连接才能对比出真正的表结构。所以如果需要对比两者的表结构是否一致,最好左连接查一次,右连接查一次。才能真正的确认两者的表结构的异同。

SELECT M.OWNER

      ,M.TABLE_NAME

      ,M.COLUMN_ID

      ,M.COLUMN_NAME

      ,M.DATA_TYPE

      ,M.DATA_LENGTH

      ,N.OWNER

      ,N.TABLE_NAME

      ,N.COLUMN_ID

      ,N.COLUMN_NAME

      ,N.DATA_TYPE

      ,N.DATA_LENGTH

FROM

(

SELECT OWNER

      ,TABLE_NAME

      ,COLUMN_ID

      ,COLUMN_NAME

      ,DATA_TYPE

      ,DATA_LENGTH

FROM DBA_TAB_COLUMNS

WHERE OWNER=&OWNER_A

  AND TABLE_NAME=&TABLE_NAME_A

) M RIGHT JOIN

(

SELECT OWNER

      ,TABLE_NAME

      ,COLUMN_ID

      ,COLUMN_NAME

      ,DATA_TYPE

      ,DATA_LENGTH

FROM DBA_TAB_COLUMNS

WHERE OWNER=&OWNER_B

  AND TABLE_NAME=&TABLE_NAME_B

) N ON  M.COLUMN_ID =N.COLUMN_ID

    AND M.COLUMN_NAME = N.COLUMN_NAME 

    AND M.DATA_TYPE = N.DATA_TYPE 

    AND M.DATA_LENGTH= N.DATA_LENGTH

ORDER BY M.TABLE_NAME, M.COLUMN_ID;

ORACLE数据库对比表结构的更多相关文章

  1. Oracle数据库的表结构 简单表的建立

  2. Oracle查询数据表结构(字段,类型,大小,备注)

    作用:想要生成整个Oracle数据库所有表结构WORD文档(数据库设计说明书) Oracle数据库字典介绍    Oracle数据字典是有表和视图组成的,存储有关数据库结构信息的一些数据库对象.数据库 ...

  3. MySQL 对比数据库的表结构

    有时候,需要对比一下测试环境和生产环境中,数据库的表结构是否有所差异.有两个常用的工具. AmpNmp.DatabaseCompare GUI 界面,支持多种数据库(MySQL.SQL Server. ...

  4. Oracle数据库丢失表排查思路

    Oracle数据库丢失表排查思路 说明:由于系统采用ID取模分表法进行Oracle数据存储,某日发现Oracle数据库中缺少对应的几张业务数据表,遂进行相关问题查询,简单记录一下排查思路: 由于我们代 ...

  5. WPF根据Oracle数据库的表,生成CS文件小工具

    开发小工具的原因: 1.我们公司的开发是客户端用C#,服务端用Java,前后台在通讯交互的时候,会用到Oracle数据库的字段,因为服务器端有公司总经理开发的一个根据Oracle数据库的表生成的cla ...

  6. 定时从远程的数据库中取数据,然后把取出来的数据插入或更新本地的oracle数据库的表

    最近项目中有一种需求: 大致需求是这样的 通过给定的 用户名和密码 要定时从远程的数据库中取数据,然后把取出来的数据插入或更新本地的oracle数据库的表 项目的结构式struts1 hibernat ...

  7. mysql对比表结构对比同步,sqlyog架构同步工具

    mysql对比表结构对比同步,sqlyog架构同步工具 对比后的结果示例: 执行后的结果示例: 点击:"另存为(S)" 按钮可以把更新sql导出来.

  8. PowerDesigner连接Oracle数据库建表序列号实现自动增长

    原文:PowerDesigner连接Oracle数据库建表序列号实现自动增长 创建表就不说了.下面开始介绍设置自动增长列. 1 在表视图的列上创建.双击表视图,打开table properties — ...

  9. Oracle 数据库整理表碎片

    Oracle 数据库整理表碎片 转载:http://kyle.xlau.org/posts/table-fragmentation.html 表碎片的来源 当针对一个表的删除操作很多时,表会产生大量碎 ...

随机推荐

  1. .NET 中获取调用方法名

    在写记录日志功能时,需要记录日志调用方所在的模块名.命名空间名.类名以及方法名,想到使用的是反射(涉及到反射请注意性能),但具体是哪一块儿还不了解,于是搜索,整理如下: 需要添加相应的命名空间: us ...

  2. [控件] 加强版 TOneSelection (改良自 Berlin 10.1 TSelection)

    本控件修改自 Delphi Berlin 10.1 的 TSelection (FMX.Controls.pas) 修改重点: 移动点显示在上方 增加(左中,上中,右中,下中)控制点,含原来的总共有 ...

  3. tp5页面输出时,搜索后跳转下一页的处理

    tp5页面输出时,搜索功能在跳转下一页时,如果不做任何处理,会返回原有是第二页输出的数据.为了保证跳转下一页时输出的是搜索到的数据,做以下处理. (要根据自己的搜索字段进行适当修改) 页面js代码,给 ...

  4. 高性能 Windows Socket 组件 HP-Socket v2.3.1-beta-1 发布

    HP-Socket 是一套通用的高性能 Windows Socket 组件包,包含服务端组件(IOCP 模型)和客户端组件(Event Select 模型),广泛适用于 Windows 平台的 TCP ...

  5. struts原理

    Struts是一个开源的web框架. 为什么会有struts? 因为我们对mvc理解的不同,可能造成不同公司写程序的时候,规范不统一,这样不利于程序的维护和扩展,所以我们有必要用一个统一的规范来开发项 ...

  6. ssh: command not found的解决办法

    原来是没装ssh的客户端软件,晕死…… yum -y install openssh-clients

  7. java集合-hashCode

    hashCode 的作用 在 Java 集合中有两类,一类是 List,一类是 Set 他们之间的区别就在于 List 集合中的元素师有序的,且可以重复,而 Set 集合中元素是无序不可重复的.对于 ...

  8. Play libs

    The play.libs package contains several useful libraries that will help you to achieve common program ...

  9. ruby(&gem) koala安装

    1.ruby下载安装 下载地址:http://railsinstaller.org/en 选择合适版本 2.gem(安装ruby时自带gem) 删除原镜像:gem sources --remove h ...

  10. 深入理解javascript(一)

    此段文章摘自大叔的博客: 此文的目的是书写可维护的javascript代码. 最小的全局变量: JavaScript通过函数管理作用域.在函数内部声明的变量只在这个函数内部,函数外面不可用.另一方面, ...