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

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. css background 背景图设置

  2. X3D中Profile如何翻译

    问题在哪 在计算机术语中,Profile其实是很难用中文对应的词汇来翻译的一个单词. 在X3D国际标准中,就出现了Profile.它把软件产品对X3D的功能实现范围和相应支持程度做了预先的约定,分为C ...

  3. springmvc中RequestMapping的解析

    在研究源码的时候,我们应该从最高层来看,所以我们先看这个接口的定义: package org.springframework.web.servlet; import javax.servlet.htt ...

  4. Scalaz(1)- 基础篇:隐式转换解析策略-Implicit resolution

    在正式进入scalaz讨论前我们需要理顺一些基础的scalaz结构组成概念和技巧.scalaz是由即兴多态(ad-hoc polymorphism)类型(typeclass)组成.scalaz typ ...

  5. MySQL配置文件mysql.ini参数详解、MySQL性能优化

    my.ini(Linux系统下是my.cnf),当mysql服务器启动时它会读取这个文件,设置相关的运行环境参数. my.ini分为两块:Client Section和Server Section.  ...

  6. Spring IoC源码解读——谈谈bean的几种状态

    阅读Spring IoC部分源码有一段时间了,经过不断的单步调试和参阅资料,对Spring容器中bean管理有了一定的了解.这里从bean的几个状态的角度出发,研究下IoC容器. 一.原材料 Xml中 ...

  7. JS高程2.在HTML中使用Javascript(1)

    1.使用<script>元素向HTML页面中插入Javascript HTML4.01中<script>标签有6个属性: (1)async:可选.表示立即下载脚本,不影响页面中 ...

  8. JavaScript实战(带收放动画效果的导航菜单)

    虽然有很多插件可用,但为了共同提高,我做了一系列JavaScript实战系列的实例,分享给大家,前辈们若有好的建议,请务必指出,免得误人子弟啊! ( 原创文章,转摘请注明:苏福:http://www. ...

  9. 【原】iOS动态性(二):运行时runtime初探(强制获取并修改私有变量,强制增加及修改私有方法等)

    OC是运行时语言,只有在程序运行时,才会去确定对象的类型,并调用类与对象相应的方法.利用runtime机制让我们可以在程序运行时动态修改类.对象中的所有属性.方法,就算是私有方法以及私有属性都是可以动 ...

  10. js控住DOM实现发布微博简单效果

    这段代码的效果具体是输入标题和内容,点击发布把消息发布出去,并使最新的消息始终在内容的最上面,代码为: <!DOCTYPE html> <html lang="en&quo ...