程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> SQL Server 新庫和舊庫數據字典的比較

SQL Server 新庫和舊庫數據字典的比較

編輯:關於SqlServer

    閱讀本文前我們首先需要了解新庫和舊庫一定要在同一個數據庫服務器的同一實例中,您最好以sa的身份來登陸,下面的這個實例腳本可以用於用於您的系統升級改造,在得到相關信息後來作數據的遷移。

declare @i int

set @i=4
 

/*3:1是需要得到新庫增加的數據字典信息。

2是需要得到舊庫多出的數據字典信息。

3是需要得到新庫增加的表的數據字典信息。

4是需要得到舊庫多出的表的數據字典信息*/

use temp  --打開舊庫
SELECT sysobjects.name AS [table], CASE WHEN CAST(syspropertIEs.[value] AS varchar)
IS NULL THEN '' ELSE CAST(syspropertIEs.[value] AS varchar) END AS 表說明,
syscolumns.name AS field, CASE WHEN CAST(propertIEs.[value] AS varchar) IS NULL
THEN '' ELSE CAST(propertIEs.[value] AS varchar) END AS 字段說明,
systypes.name AS type, syscolumns.length,
ISNULL(COLUMNPROPERTY(syscolumns.id, syscolumns.name, 'Scale'), 0)
AS 小數位數, syscolumns.isnullable AS isnull,
CASE WHEN syscomments.text IS NULL
THEN '' ELSE syscomments.text END AS [Default],
CASE WHEN COLUMNPROPERTY(syscolumns.id, syscolumns.name, 'IsIdentity')
= 1 THEN '√' ELSE '' END AS 標識, CASE WHEN EXISTS
(SELECT 1
FROM sysobjects
WHERE xtype = 'PK' AND name IN
(SELECT name
FROM sysindexes
WHERE indid IN
(SELECT indid
FROM sysindexkeys
WHERE id = syscolumns.id AND colid = syscolumns.colid)))
THEN '√' ELSE '' END AS 主鍵 into #old
FROM syscolumns INNER JOIN
sysobjects ON sysobjects.id = syscolumns.id INNER JOIN
systypes ON syscolumns.xtype = systypes.xtype LEFT OUTER JOIN
sysproperties properties ON syscolumns.id = propertIEs.id AND
syscolumns.colid = propertIEs.smallid LEFT OUTER JOIN
sysproperties ON sysobjects.id = syspropertIEs.id AND
syspropertIEs.smallid = 0 LEFT OUTER JOIN
syscomments ON syscolumns.cdefault = syscomments.id
WHERE (sysobjects.xtype = 'U')

use accdb --打開新庫
SELECT sysobjects.name AS [table], CASE WHEN CAST(syspropertIEs.[value] AS varchar)
IS NULL THEN '' ELSE CAST(syspropertIEs.[value] AS varchar) END AS 表說明,
syscolumns.name AS field, CASE WHEN CAST(propertIEs.[value] AS varchar) IS NULL
THEN '' ELSE CAST(propertIEs.[value] AS varchar) END AS 字段說明,
systypes.name AS type, syscolumns.length,
ISNULL(COLUMNPROPERTY(syscolumns.id, syscolumns.name, 'Scale'), 0)
AS 小數位數, syscolumns.isnullable AS isnull,
CASE WHEN syscomments.text IS NULL
THEN '' ELSE syscomments.text END AS [Default],
CASE WHEN COLUMNPROPERTY(syscolumns.id, syscolumns.name, 'IsIdentity')
= 1 THEN '√' ELSE '' END AS 標識, CASE WHEN EXISTS
(SELECT 1
FROM sysobjects
WHERE xtype = 'PK' AND name IN
(SELECT name
FROM sysindexes
WHERE indid IN
(SELECT indid
FROM sysindexkeys
WHERE id = syscolumns.id AND colid = syscolumns.colid)))
THEN '√' ELSE '' END AS 主鍵 into #new
FROM syscolumns INNER JOIN
sysobjects ON sysobjects.id = syscolumns.id INNER JOIN
systypes ON syscolumns.xtype = systypes.xtype LEFT OUTER JOIN
sysproperties properties ON syscolumns.id = propertIEs.id AND
syscolumns.colid = propertIEs.smallid LEFT OUTER JOIN
sysproperties ON sysobjects.id = syspropertIEs.id AND
syspropertIEs.smallid = 0 LEFT OUTER JOIN
syscomments ON syscolumns.cdefault = syscomments.id
WHERE (sysobjects.xtype = 'U') 


if @i=1
begin
select n.* --新庫與舊庫相比較後新庫增加的數據字典信息
from #new n left join #old o on n.[table]=o.[table] and n.field=o.fIEld where o.[table] is null
or o.field is null order by n.[table],n.fIEld
end
else
begin
if @i=2
begin
select o.* --新庫與舊庫相比較後舊庫多出的數據字典信息
from #new n right join #old o on n.[table]=o.[table] and n.field=o.fIEld where n.[table] is null
or n.field is null order by o.[table],o.fIEld
end
else
begin
if @i=3
begin
select * --新庫與舊庫相比較後新庫增加的表的數據字典信息
from #new where [table] <> all(select [table] from #old ) order by [table],fIEld
end
else
begin
if @i=4
begin
select * --新庫與舊庫相比較後舊庫多出的表的數據字典信息
from #old where [table] <> all(select [table] from #new ) order by [table],fIEld
end
else
begin
select '出錯啦'
end    
end    
end   
end

drop table #old
drop table #new

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved