查询SQlServer相同表结构差异
USE [数据库名]
GO DECLARE @TableName1 NVARCHAR(100);
DECLARE @TableName2 NVARCHAR(100); DECLARE @DataName1 NVARCHAR(100);
DECLARE @DataName2 NVARCHAR(100); SET @DataName1='库1';
SET @DataName2='库2'; SET @TableName1='表1';
SET @TableName2='表2'; SET @TableName2=@TableName1; SELECT
(case when a.colorder=1 then d.name else null end) 表名1,
a.name 字段名1,
(case when (SELECT count(*) FROM sysobjects
WHERE (name in (SELECT name FROM sysindexes
WHERE (id = a.id) AND (indid in
(SELECT indid FROM sysindexkeys
WHERE (id = a.id) AND (colid in
(SELECT colid FROM syscolumns WHERE (id = a.id) AND (name = a.name)))))))
AND (xtype = 'PK'))>0 then '√' else '' end) 主键1,b.name 类型1,
COLUMNPROPERTY(a.id,a.name,'PRECISION') as 长度1
,1 AS aa
INTO #temp1
FROM syscolumns a
left join systypes b on a.xtype=b.xusertype
inner join sysobjects d on a.id=d.id and d.xtype='U' and d.name<>'dtproperties'
left join 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
left join sys.extended_properties f on d.id=f.class and f.minor_id=0
where b.name is not null AND (SELECT COUNT(1) FROM Master..SysDatabases sysA WHERE sysA.name=@DataName1 )>0 AND d.name=@TableName1 --WHERE d.name='要查询的表' --如果只查询指定表,加上此条件
order by a.name,a.id,a.colorder SELECT
(case when a.colorder=1 then d.name else null end) 表名2,
a.name 字段名2,
(case when (SELECT count(*) FROM sysobjects
WHERE (name in (SELECT name FROM sysindexes
WHERE (id = a.id) AND (indid in
(SELECT indid FROM sysindexkeys
WHERE (id = a.id) AND (colid in
(SELECT colid FROM syscolumns WHERE (id = a.id) AND (name = a.name)))))))
AND (xtype = 'PK'))>0 then '√' else '' end) 主键2,b.name 类型2,
COLUMNPROPERTY(a.id,a.name,'PRECISION') as 长度2
,1 AS aa
INTO #temp2
FROM syscolumns a
left join systypes b on a.xtype=b.xusertype
inner join sysobjects d on a.id=d.id and d.xtype='U' and d.name<>'dtproperties'
left join 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
left join sys.extended_properties f on d.id=f.class and f.minor_id=0
where b.name is not null AND (SELECT COUNT(1) FROM Master..SysDatabases sysA WHERE sysA.name=@DataName2 )>0 AND d.name=@TableName2 --WHERE d.name='要查询的表' --如果只查询指定表,加上此条件
order by a.name,a.id,a.colorder SELECT * FROM (
SELECT COUNT(1) AS 表1字段数量 FROM #temp1
)a ,
(
SELECT COUNT(1) AS 表2字段数量 FROM #temp2 )b SELECT COUNT(1) FROM #temp1 a LEFT JOIN #temp2 b ON a.字段名1=b.字段名2 WHERE a.长度1!=ISNULL(b.长度2,'') OR a.类型1!=ISNULL(b.类型2,''); SELECT COUNT(1) FROM #temp1 a RIGHT JOIN #temp2 b ON a.字段名1=b.字段名2 WHERE ISNULL(a.长度1,'')!=b.长度2 or b.类型2!=ISNULL(a.类型1,''); SELECT a.字段名1,b.字段名2,a.类型1,b.类型2,a.长度1,b.长度2 INTO #temp_1 FROM #temp1 a LEFT JOIN #temp2 b ON a.字段名1=b.字段名2 SELECT a.字段名1,b.字段名2,a.类型1,b.类型2,a.长度1,b.长度2 INTO #temp_2 FROM #temp1 a RIGHT JOIN #temp2 b ON a.字段名1=b.字段名2 SELECT * FROM #temp_1;
SELECT * FROM #temp_2; DROP TABLE #temp1; DROP TABLE #temp2; DROP TABLE #temp_1; DROP TABLE #temp_2;
GO
查询SQlServer相同表结构差异的更多相关文章
- 查询sqlserver数据库表的记录数
SELECT a.name, b.rows FROM sysobjects AS a INNER JOINsysindexes AS b ON a.id = b.idWHERE (a.type = ' ...
- SqlServer查询数据库所有表
//SqlServer查询数据库所有表SELECT * FROM SYSOBJECTS WHERE TYPE='U' and name like '%dict%'
- 【转载】C#常用数据库Sqlserver通过SQL语句查询数据库以及表的大小
在Sqlserver数据库中,一般我们查看数据库的大小可以通过查找到数据库文件来查看,但如果要查找数据表Table的大小的话,则不可通过此方法,在Sqlserver数据库中,提供了相应的SQL语句来查 ...
- SQLserver、MySQL、ORCAL查询数据库、表、表中字段以及字段类型
一.SQLServer命令 1.查询SQLServer中的每个数据库 SELECT * from sysdatabases 2.查询SQLServer中指定数据库的所有表名 select name f ...
- jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上
jsp中使用Servlet查询SQLSERVER数据库中的表的信息,并且打印在屏幕上 1.JavaBean的使用 package com.zheng; public class BookBean { ...
- NHibernate中,查询SqlServer数据库多个实体对象
关于datetime类型使用: Oracle: "and tb.EffectiveDate >= to_date(?,'yyyy-mm')" Sql: "an ...
- SQLSERVER新建表的时候页面分配情况是怎样的?
SQLSERVER新建表的时候页面分配情况是怎样的? 再次感谢sqlskill网站和转载sqlskill网站文章并翻译的人,因为您们的转载和翻译让小弟又学习到新的东西o(∩_∩)o 文章中用到的工具: ...
- sql server sql查询数据库的表,字段,主键,自增,字段类型等信息
1.查询数据表的属性(名称.说明.是否主键.数据类型.是否自增) SELECT t1.name columnName,case when t4.id is null then 'false' else ...
- SqlServer数据库表导入SqlLite数据库表保持日期时间类型字段的格式
在写查询功能的过程中遇到一个这样的问题:按日期范围查询,sql语句是:where dt>=用户选择起始日期&&dt<=用户选择结束日期.数据库中的数据如图1,我选择的测试数 ...
随机推荐
- Java如何设置线程的优先级?
在Java编程中,如何设置线程的优先级? 以下示例如何使用setPriority()方法来设置线程的优先级. package com.yiibai; public class SettingPrior ...
- (转)android媒体--stagefright概述【一】
转自:http://blog.csdn.net/loovejava/article/details/8971790 最近杂七杂八的忙碌着,前几天看了下这部分主要是stagefright模块的,所以更改 ...
- ubuntu -- 系统目录结构
1./:目录属于根目录,是所有目录的绝对路径的起始点,Ubuntu 中的所有文件和目录都在跟目录下. 2./etc:此目录非常重要,绝大多数系统和相关服务的配置文件都保存在这里,这个目录的内容一般只能 ...
- XML中二进制数据的处理方法
原文链接:http://www.west263.com/www/info/22308-1.htm 在xml中,所有的数据都是以文本的形式来显示,但是二进制数据不能直接以文本格式来表示,那xml又是怎么 ...
- 软渲染 SoftRender
弄了这几年OpenGL对管线还是算比较熟悉,写起来也比较顺,不过每个顶点都要经过一堆变换,着实感到效率的重要.(矩阵乘顶点没有SSE加速啊)装个B,半天的成果..(主要很多东西都写好了直接拿来) // ...
- ssh方式与服务器建立连接
package com.ustcinfo.cinas.pmng.util; import java.io.BufferedReader; import java.io.InputStream; imp ...
- Spring AOP的日志记录
现在的项目是Spring+MyBatis,前段时间项目经理让我干了一个活,就是给所有的controller里的所有方法加上日志记录的代码,其实没有多少,也就300来个方法,也没有抱怨什么,一边打着瞌睡 ...
- faster-rcnn原理及相应概念解释
R-CNN --> FAST-RCNN --> FASTER-RCNN R-CNN: (1)输入测试图像: (2)利用selective search 算法在图像中从上到下提取2000个左 ...
- 【Oracle】BLOB
1.データベースからの読み込み Dim strSql As String = "select IMG from TBL where ID=XX" Dim cmd As New Or ...
- JAVA内存泄露分析及解决
一,问题产生 项目采用Tomcat6.0为服务器,数据库为mysql5.1,数据库持久层为hibernate3.0,以springMVC3.0为框架,项目开发完成后,上线前夕进行稳定性拷机,测 ...