比较两个数据库的表结构差异

/*--比较两个数据库的表结构差异--*/

/*--调用示例
exec p_comparestructure ‘DBNAME1‘,‘DBNAME2‘
exec p_comparestructure ‘DBNAME2‘,‘DBNAME3‘
--*/
ALTER proc [dbo].[p_comparestructure]
@dbname1 varchar(250),--要比较的数据库名1
@dbname2 varchar(250) --要比较的数据库名2
as
create table #tb1(表名1 varchar(250),字段名 varchar(250),序号 int,标识 bit,主键 bit,类型 varchar(250),
占用字节数 int,长度 int,小数位数 int,允许空 bit,默认值 sql_variant,字段说明 sql_variant)

create table #tb2(表名2 varchar(250),字段名 varchar(250),序号 int,标识 bit,主键 bit,类型 varchar(250),
占用字节数 int,长度 int,小数位数 int,允许空 bit,默认值 sql_variant,字段说明 sql_variant)

--得到数据库1的结构
exec(‘insert into #tb1 SELECT
表名=d.name,字段名=a.name,序号=a.colid,
标识=case when a.status=0x80 then 1 else 0 end,
主键=case when exists(SELECT 1 FROM ‘[email protected]+‘..sysobjects where xtype=‘‘PK‘‘ and parent_obj=a.id and name in (
SELECT name FROM ‘[email protected]+‘..sysindexes WHERE indid in(
SELECT indid FROM ‘[email protected]+‘..sysindexkeys WHERE id = a.id AND colid=a.colid
))) then 1 else 0 end,
类型=b.name,占用字节数=a.length,长度=a.prec,小数位数=a.scale,允许空=a.isnullable,
默认值=isnull(e.text,‘‘‘‘),字段说明=isnull(g.[value],‘‘‘‘)
FROM ‘[email protected]+‘..syscolumns a
left join ‘[email protected]+‘..systypes b on a.xtype=b.xusertype
inner join ‘[email protected]+‘..sysobjects d on a.id=d.id and d.xtype=‘‘U‘‘ and d.name <>‘‘dtproperties‘‘
left join ‘[email protected]+‘..syscomments e on a.cdefault=e.id
left join sys.extended_properties g
ON
a.ID=g.major_id AND a.COLID=g.minor_id
order by a.id,a.colorder‘)

--得到数据库2的结构
exec(‘insert into #tb2 SELECT
表名=d.name,字段名=a.name,序号=a.colid,
标识=case when a.status=0x80 then 1 else 0 end,
主键=case when exists(SELECT 1 FROM ‘[email protected]+‘..sysobjects where xtype=‘‘PK‘‘ and parent_obj=a.id and name in (
SELECT name FROM ‘[email protected]+‘..sysindexes WHERE indid in(
SELECT indid FROM ‘[email protected]+‘..sysindexkeys WHERE id = a.id AND colid=a.colid
))) then 1 else 0 end,
类型=b.name,占用字节数=a.length,长度=a.prec,小数位数=a.scale,允许空=a.isnullable,
默认值=isnull(e.text,‘‘‘‘),字段说明=isnull(g.[value],‘‘‘‘)
FROM ‘[email protected]+‘..syscolumns a
left join ‘[email protected]+‘..systypes b on a.xtype=b.xusertype
inner join ‘[email protected]+‘..sysobjects d on a.id=d.id and d.xtype=‘‘U‘‘ and d.name <>‘‘dtproperties‘‘
left join ‘[email protected]+‘..syscomments e on a.cdefault=e.id
left join sys.extended_properties g
ON
a.ID=g.major_id AND a.COLID=g.minor_id
order by a.id,a.colorder‘)
--and not exists(select 1 from #tb2 where 表名2=a.表名1)
select 比较结果=case when a.表名1 is null and b.序号=1 then ‘库1缺少表:‘+b.表名2
when b.表名2 is null and a.序号=1 then ‘库2缺少表:‘+a.表名1
when a.字段名 is null and exists(select 1 from #tb1 where 表名1=b.表名2) then ‘库1 [‘+b.表名2+‘] 缺少字段:‘+b.字段名
when b.字段名 is null and exists(select 1 from #tb2 where 表名2=a.表名1) then ‘库2 [‘+a.表名1+‘] 缺少字段:‘+a.字段名
when a.标识 <>b.标识 then ‘标识不同‘
when a.主键 <>b.主键 then ‘主键设置不同‘
when a.类型 <>b.类型 then ‘字段类型不同‘
when a.占用字节数 <>b.占用字节数 then ‘占用字节数‘
when a.长度 <>b.长度 then ‘长度不同‘
when a.小数位数 <>b.小数位数 then ‘小数位数不同‘
when a.允许空 <>b.允许空 then ‘是否允许空不同‘
when a.默认值 <>b.默认值 then ‘默认值不同‘
when a.字段说明 <>b.字段说明 then ‘字段说明不同‘
else ‘‘ end,
*
from #tb1 a
full join #tb2 b on a.表名1=b.表名2 and a.字段名=b.字段名
where a.表名1 is null or a.字段名 is null or b.表名2 is null or b.字段名 is null
or a.标识 <>b.标识 or a.主键 <>b.主键 or a.类型 <>b.类型
or a.占用字节数 <>b.占用字节数 or a.长度 <>b.长度 or a.小数位数 <>b.小数位数
or a.允许空 <>b.允许空 or a.默认值 <>b.默认值 or a.字段说明 <>b.字段说明
order by isnull(a.表名1,b.表名2),isnull(a.序号,b.序号)--isnull(a.字段名,b.字段名)

时间: 2024-08-10 02:10:18

比较两个数据库的表结构差异的相关文章

sql server新旧数据库的表结构差异

问题:工作过程中,不管是什么项目,伴随着项目不断升级版本,对应的项目数据库业务版本也不断升级,数据库出现新增表.修改表.删除表.新增字段.修改字段.删除字段等变化,如果人工检查,数据库表和字段比较多的话,工作量就非常大. 解决方案:这里博主为大家分享一个在工作过程中编写的自动检查数据库表结构版本差异的通用脚本,只需要把新旧数据库名称批量替换成实际的名称就可以,支持通过链接服务器跨服务器检查不同服务器的两个数据库表结构差异. 脚本: /* 使用说明:Old数据库为DB_V1,New数据库为[loc

(转载) 两个数据库比较 对比视图存储过程及表结构差异

一.视图和存储过程比较 [原理]利用系统表"sysobjects"和系统表"syscomments",将数据库中的视图和存储过程进行对比.系统表"sysobjects"之前有详细介绍过,有兴趣可以看看:SQL Server系统表sysobjects介绍与使用 [代码] /*--调用示例 exec p_compdb 'DBNAME1','DBNAME2' exec p_compdb 'DBNAME2','DBNAME3' --*/ CREATE p

两个数据库比较 对比视图存储过程及表结构差异

两个数据库比较 对比视图存储过程及表结构差异 一.视图和存储过程比较 [原理]利用系统表“sysobjects"和系统表“syscomments”,将数据库中的视图和存储过程进行对比.系统表"sysobjects"之前有详细介绍过,有兴趣可以看看:SQL Server系统表sysobjects介绍与使用 如果你看到这段文字,说明您正使用RSS阅读或转自<一棵树-博客园>,原文地址:http://www.cnblogs.com/atree/p/db-compare-

比较两个数据库中表的不同

二.数据表结构比较 [原理]利用系统表“sysobjects"."sysindexes"."sysindexkeys". “syscomments”."sysclumns"."systypes"."extended_properties",将数据库中的表结构进行对 比.(涉及到系统表比较多.就不一一介绍.直接上代码.) [代码] /*--比较两个数据库的表结构差异--*/ /*--调用示例 exe

Java对比两个数据库中的表和字段,写个冷门的东西

Java对比两个数据库中的表和字段,写个冷门的东西 转载的 来源网络 目前所在的项目组距离下个版本上线已经很近了,就面临了一个问题:开发人员在开发库上根据需要增加数据表.数据字段.或者变更了字段类型或者字段长度等等. 由于时间比较紧迫,导致在开发过程中不可能一一把DDL数据库脚本记录下来,在比较大的项目中,比如我所在项目开发的系统大概包含了800张左右的表,字段上10000个的情况下,人工处理明显不可行,所以我们就得通过程序来判断比对,哪些是我们需要新增加的表,哪些是我们需要新增加的字段,哪些是

判断两个数据库中不一样的表和存储过程

---两表结构不一样SELECT a.a1,a.a2,a.a3,a.length from(SELECT a.a1,a.a2,a.a3,a.length, b.a1 AS b1,b.a2 AS b2,b.a3 AS b3,b.length AS b4  from (select o.name AS a1, c.name AS a2,t.name AS a3,c.length from dbf.sys.syscolumns cinner join dbf.sys.systypes t on c.x

两个数据库表同步的可视化WEB同步程序

因业务升级,现有一个数据库中的表需要与先前项目中的表进行数据同步,停用先前的表,这两个表只能按其中相同的一个字段同步,认真研究了一下,用WEB程序进行了处理,可视化显示处理进度,同步操作结果.使用到的相关技术资料: 1.界面使用QUI(节省很多界面开发时间) 2.Jquery,AJax 同步请求(异步会有问题的) 3,吉日嘎拉底层数据库访问(可完美实现多种数据库表之间的同步,如目标数据库是MSSQL,源数据库是Oracle等) 前端截图:可视化显示处理进度及结果 前端部分JS 后台使用通用权限管

在db2中 两个数据库之间的两个表的联合查询

大家好,今天遇到了在db2中 两个数据库之间的两个表的联合查询我知道oracle中有dblink,可是不知到db2的两个数据库联合查询怎么处理我找了类似于比如两个数据库: db1,db2用户名密码select * from db1.用户名.密码,db2.用户名.密码 where db1.NM=db2.NM可是这样不好用啊请各位帮忙谢谢 DB2有联邦数据库的,你可以查一下. 1.要看目录数据库请用:db2 list db directory这些信息应该是放系统表中.(既不是什么注册表.也不是什么文

PLSQL_Material View物化视图的基本概念和用法 (概念)(以物化视图的方式同步两个数据库间的表或实时备份重要表)

2014-06-08 BaoXinjian 1. 用法 物化视图是包括一个查询结果的数据库对象,它是远程数据的的本地副本,或者用来生成基于数据表求和的汇总表. 物化视图存储基于远程表的数据,也可以称为快照.对于复制,物化视图允许你在本地维护远程数据的副本,这些副本是只读的. 如果你想修改本地副本,必须用高级复制的功能.当你想从一个表或视图中抽取数据时,你可以用从物化视图中抽取. 对于数据仓库,创建的物化视图通常情况下是聚合视图,单一表聚合视图和连接视图. 实现两个数据库之间的数据同步,可以存在时