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

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. 炉石传说 C# 设计文档(序)

    经过3个月的开发,有很多感触. 以前一直以为技术是开发成败的第一因素,现在发现,等到你代码写的时间够长,经验够丰富,什么功能都能随手完成,对于业务的分析能力变成了第一位. 炉石山寨版的BS版本用到的H ...

  2. thinkphp中assign()和display()区别和用法

  3. Hibernate---detached entity passed to persist一个解决方法

    1.查看id生成策略,2.查看是否是手动设置的id :3.查看实体对象映射配置是否正确. 例如: public Emplopes(String name, char gender) { super(n ...

  4. 框架SpringMVC笔记系列 一 基础

    主题:SpringMVC 学习资料参考网址: 1.http://www.icoolxue.com 2.http://aokunsang.iteye.com/blog/1279322 1.SpringM ...

  5. Java final类

    如果说整个类都是final(在它的定义前冠以final关键字),就表明自己不希望从这个类继承,或者不允许其他任何人采取这种操作.换言之,出于这样或那样的原因,我们的类肯定不需要进行任何改变:或者出于安 ...

  6. WinForm 窗体应用程序(进阶)之一

    进程: 进程,简单的说,就是让你的程序启动另一个程序. 1.Process.Start("calc");//启动计算器 弊端:只认识系统自带的程序,如果写错系统会崩溃. 2. // ...

  7. java内存模型-基础

    基础 并发编程模型的分类 在并发编程中,我们需要处理两个关键问题:线程之间如何通信及线程之间如何同步(这里的线程是指并发执行的活动实体).通信是指线程之间以何种机制来交换信息.在命令式编程中,线程之间 ...

  8. 一种基于annotation的Spring-mvc权限控制方法

    简介 本文介绍一种采用annotation来对spring-mvc进行权限控制的方法. 通过枚举类来定义权限项. 将annotation标注到需要控制权限的spring-mvc方法上. 然后,在spr ...

  9. Ionic 今天发布了Windows 桌面版的IDE Ionic Lab

    Ionic简介: Ionic 是一个强大的 HTML5 应用程序开发框架,号称 Advanced HTML5 Hybrid Mobile AppFramework 是 AngularJS 移动端解决方 ...

  10. FormsAuthentication身份认证源代码

    使用FormsAuthentication类可以实现身份认证功能,这里提供一个asp.net项目的源代码,项目名称KWS.项目实现了登录.退出和判断身份的功能. 关于项目 点击这里下载源代码 http ...