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

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. WCF Throttling 限流的三道闸口

    WCF Throttling 限流的三道闸口 一.WCF Throttling  流量限制简介 我们期望WCF服务端能够处理尽可能多的并发请求,但是资源是有限的,服务不可能同时处理无限多的并发请求,如 ...

  2. 透过IL看C#:switch语句(转)

    透过IL看C# switch语句(上) 摘要: switch语句是 C#中常用的跳转语句,可以根据一个参数的不同取值执行不同的代码.本文介绍了当向 switch语句中传入不同类型的参数时,编译器为其生 ...

  3. css背景图

  4. hibernate----component-entity (人-地址-学校)

    package com.ij34.dao; import javax.persistence.*; @Entity @Table(name="school_inf") public ...

  5. Map遍历两种方式

    Java代码 Map<String,String> map=new HashMap<String,String>(); map.put("username" ...

  6. mysql分页查询详解

    我们做的后端项目一般都会有admin管理端,当管理端将要展示数据的时候,就需要用到分页.所以分页的考查在面试中也相当多.在mysql中进行分页查询时,一般会使用limit查询,而且通常查询中都会使用o ...

  7. PHP mongodb AR

    <?php /** * @author xiaojiang */ abstract class MongoAr{ private $db = null; public function __co ...

  8. 原生JS:Math对象详解

    Math对象 本文参考MDN做的详细整理,方便大家参考MDN Math 也是一个内置对象, 为数学常量和数学函数提供了属性和方法,而不是一个函数对象. 与其它全局对象不同的是, Math 不是一个构造 ...

  9. kindeditor-在线编辑器

    写在前面的话: 今天是第一次写博客,很值得纪念,希望能够和大神们一起交流技术,一起进步...来自<一只有梦想的前端小白> 最近项目中需要实现图文混排的效果,所以研究了下在线编辑器-- ki ...

  10. 一维Poisson方程计算

    package com.smartmap.algorithm.equation.differential.partial.ellipsoidal; import java.io.FileOutputS ...