ホームページ >データベース >mysql チュートリアル >最近的项目,也许是产品吧,用的客户好几个,数据库也经常更新,

最近的项目,也许是产品吧,用的客户好几个,数据库也经常更新,

WBOY
WBOYオリジナル
2016-06-07 14:59:321232ブラウズ

/*1。比较数据库表不一样的 select distinct a.id,d.name as TableName--,a.name as ColumeName from [onwerbuild_wjl2].dbo.syscolumns a,[onwerbuild_wjl2].dbo.sysobjects d where d.xtype='U' and d.name not in (select c.name from [onwerbuild_wjl_m

/*1。比较数据库表不一样的
select distinct a.id,d.name as TableName--,a.name as ColumeName
from [onwerbuild_wjl2].dbo.syscolumns a,[onwerbuild_wjl2].dbo.sysobjects d
where d.xtype='U' and 
d.name not in
(select c.name from [onwerbuild_wjl_m].dbo.syscolumns b,[onwerbuild_wjl_m].dbo.sysobjects c where c.xtype='U' and b.id=c.id)
 and a.id=d.id order by d.name

*/
--2.比较数据库字段
--查询库A比库B多了多少字段
--
USE onwerbuild--库A

GO
--删除所有数据
--建表
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[Test_del]') and OBJECTPROPERTY(id, N'IsUserTable') = 1)
drop table [dbo].[Test_del]
GO

CREATE TABLE [dbo].[Test_del] (
 [TableName] [varchar] (100) COLLATE Chinese_PRC_CI_AS NULL ,
 [ColumeName] [varchar] (100) COLLATE Chinese_PRC_CI_AS NULL
) ON [PRIMARY]
GO


DELETE FROM dbo.Test_del

DECLARE @table_name varchar(50)
DECLARE abc CURSOR FOR

--先取出一个表
select d.name as TableName
from [onwerbuild_AS].dbo.sysobjects d --库A
where d.xtype='U' order by d.name

OPEN abc

FETCH NEXT FROM abc
into @table_name

WHILE (@@FETCH_STATUS = 0)
begin
--一个表一个表的对应
--把不同的字段插入
USE onwerbuild_AS--库A
 Insert into [onwerbuild].dbo.Test_del
select d.name as TableName,a.name as ColumeName
from [onwerbuild_AS].dbo.syscolumns a,[onwerbuild_AS].dbo.sysobjects d --库A
where d.name=@table_name 
and a.name not in
(select b.name from [onwerbuild].dbo.syscolumns b,[onwerbuild].dbo.sysobjects c where c.name=@table_name and b.id=c.id)--库B
 and a.id=d.id order by d.name
 FETCH NEXT FROM abc
 into @table_name

set nocount on
end
CLOSE abc
DEALLOCATE abc

select * from [onwerbuild].dbo.Test_del
select distinct TableName from [onwerbuild].dbo.Test_del
GO

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。