查询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
时间: 2024-10-09 09:31:33

查询SQlServer相同表结构差异的相关文章

sqlserver锁表、解锁、查看锁表

? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 面演示一个实例,它使用sys.dm_tran_locks动态视图监视数据库中锁的活动. 打开一个查询窗口,执行如下语句: USE AdventureWorks BEGIN TRAN SELECT ProductID, ModifiedDate FROM Production.ProductDocument WITH (TABLOCKX) 打开另一个查询窗口

010.简单查询、分组统计查询、多表连接查询(sql实例)

-------------------------------------day3------------ --添加多行数据:------INSERT [INTO] 表名 [(列的列表)] --SELECT UNION --SELECT 'HAHA',1,32--UNION ALL --全部显示/显示重复数据 即使集合相同--UNION---------将查询的两个结果集合并.结构必须一致 -->常见面试题 --SELECT 'HEHE',2,33------将查询结果添加到列表中(子查询)IN

用SQL server导出到oracle,查询时提示“表或视图不存在ORA-00942”错误

用SQL server2005的导出工具,将数据导出表到oracle,表名称里看到有这张表了,但查询或删除时都提示“ORA-00942表或者试图不存在”的错误,上网查了一下,是如下原因: “查询或删除名称存在的表时,却提示不存在,你看看在user_tables里这几个表名是小写吗? 那说明你建表的时候肯定带引号了,请select的时候也带上引号.例如:select * from "tableName",可以看出如果在SQLserver中,如果表名是小写的,那导入到oracle时,建表时

两个表联合查询获取聊天表中用户最新的一条聊天数据

一个用户表,一个聊天记录表,两个表联合查询获取聊天表中用户最新的一条聊天数据 select c.contentfrom sixin as c where c.tid = a.user_idorder by ctime desc limit 0,1) as content,(select c.statusfrom sixin as c where c.tid = a.user_idorder by ctime desc limit 0,1) as status from users as a, s

Django-rest-framework多条件查询/分页/多表Json

Django-rest-framework多条件查询/分页/多表Json django-rest-framework多条件查询需要覆写ListAPIView.get_queryset方法,代码示例: def get_queryset(self):     """     使用request.query_params实现多条件查询,也可以使用django filter ,较简单的     方法是在filter_fields中指定要过滤的字段,但只能表示等值,不灵活,灵活的方式是

SQLServer清空表

TRUNCATE TABLE TABLE_NAME这个不记日志.delete table table_name这个记日志drop table table_name删除表 TRUNCATE语法TRUNCATE TABLE TABLE_NAME如:TRUNCATE TABLE TEST删除TEST表中的所有数据 SQLServer清空表,布布扣,bubuko.com

【Oracle 常用查询】oracle表空间使用率统计查询

参考1 --查询表空间使用情况 SELECT Upper(F.TABLESPACE_NAME) "表空间名", D.TOT_GROOTTE_MB "表空间大小(M)", D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)", To_char(Round(( D.TOT_GROOTTE_MB - F.TOTAL_BYTES ) / D.TOT_GROOTTE_MB * 100, 2), '990.99') || '

Linux命令:MySQL系列之五--SELECT单表查询、多表查询升级及删除,插入

SELECT:查询 SELECT select-list FROM tb WHERE qualification  根据标准qualification查找对应的行 查询语句类型:  qualification条件  field领域  distinct独特的 简单查询: 多表查询: 子查询: SELECT * FROM tb_name: 查询tb_name表的所有信息 SELECT field1,field2 FROM tb_name: 投影显示所设定的领域条目(field),一个field就是一

查询结果一直处于查询状态,表被锁。

执行一条查询语句,结果一直显示的是查询状态,没有出来结果.原来是在执行的一个存储过程里加了事务,但是这个执行存储过程出了错.于是想到,肯定是这个表被锁住了. 接下来就好办了. select   request_session_id   spid,OBJECT_NAME(resource_associated_entity_id) tableName from   sys.dm_tran_locks where resource_type='OBJECT' spid   锁表进程 tableNam