sql server2000中查询对数据库中的哪些表进行修改过

本文介绍了在SQL Server 2000中查询哪些表被修改过的方法,包括通过Log Explorer查看具体修改时间和内容,以及利用T SQL查询sysobjects表来获取表的修改次数。

 

在网上遇到过有朋友问“关于如何查询哪些表进行修改过”这方面的问题,其实要查看的话有两种方式:一方面是通过log explorer,另外一种是通过查看sysobjects,结合tsql来进行查询。

本测试环境是sql server 2000

一、通过log explorer

连接到服务器后,选择要查看的数据库,然后在View DDL Commands中可以看到每个表修改的时间与内容。

二、通过T SQL查询

如果不需要知道表的具体的修改时间的话,那么通过查看sysobjects就可以知道哪些表进行修改了,并且可以查看出该表修改了几次。

方法:在sysobjects表中有一列

schema_ver,

int

版本号,该版本号在每次表的架构更改时都增加。

该列默认值为0,当某个表修改后,该表在sysobjects对应的行的该列值就会发生改变,改变一次,该列值加16。那么通过查看该列就可以知道,那个表进行了修改,并且用该值除以16就可以知道该列修改了几次。

例如:

if not object_id('tb') is null

       drop table tb

Go

Create table tb([Type] nvarchar(1),[sums] int,[dates] Datetime)

Insert tb

select N'A',5,'2008-11-11' union all

select N'B',5,'2008-11-11' union all

Go

Select * from tb

 

第一次修改:

select name,id,schema_ver into # from sysobjects where type='u'

select * from #

 

alter table tb

add col1 varchar(10)

 

select '修改过的表',s.name,s.id,修改次数=s.schema_ver/16

from sysobjects s join # t on s.schema_ver<>t.schema_ver and s.id=t.id

drop table #

 

--查询结果

修改过的表 tb    891866244   1

 

第二次修改:

select name,id,schema_ver into # from sysobjects where type='u'

select * from #

 

alter table tb

add col2 varchar(10)

 

select '修改过的表',s.name,s.id,修改次数=s.schema_ver/16

from sysobjects s join # t on s.schema_ver<>t.schema_ver and s.id=t.id

 

drop table #

 

--查询结果

修改过的表 tb    891866244   2

 

    至于sql server2005中尚未进行测试,待续。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值