sql server2000中查询对数据库中的哪些表进行修改过
来源:互联网 发布:java获取qq好友列表 编辑:程序博客网 时间:2024/05/21 15:47
在网上遇到过有朋友问“关于如何查询哪些表进行修改过”这方面的问题,其实要查看的话有两种方式:一方面是通过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中尚未进行测试,待续。
- sql server2000中查询对数据库中的哪些表进行修改过
- 利用Sql Server2000的规则对数据库中的数据进行限制
- 在SQL Server2000中修改系统表
- sql server中查询数据库中有哪些表
- C#实现对SQL数据库中的表的查询、添加、修改、删除数据
- 查询 某个字段存在于数据库中的哪些表中
- 请教怎样备份SQL Server2000中的表至硬盘,然后再导入数据库中?
- SQL Server2000中修改表的所有者的方法
- sql server2000中实现递归查询
- sql server2000中怎么对存储过程进行加密和解密
- sql server2000中怎么对存储过程进行加密和解密
- sql server2000中怎么对存储过程进行加密和解密
- 监控SQL:通过SQL Server的DML触发器来监控哪些IP对表的数据进行了修改(2)
- SQLServer中用T—SQL命令查询一个数据库中有哪些表的sql语句
- SQLServer中用T—SQL命令查询一个数据库中有哪些表的sql语句
- Oracle数据库中进行树形查询sql
- Java对MySQL数据库进行连接、查询和修改
- Java对MySQL数据库进行连接、查询和修改
- 加入JLU开源社区有感
- 技术以外的功夫
- 简单批处理文件设计
- 蛙
- 人生点滴感悟...
- sql server2000中查询对数据库中的哪些表进行修改过
- T检验、F检验和统计学意义(P值或sig值)(转载)
- Federa9 下的httpd安装
- 3ds max—插件概论
- iBatis学习(四) 动态Mapped Statement
- VB6中如何使MSHFlexGrid选中行反色显示?
- iBatis学习(五) 避免SELECT N+1
- Bill Gates vs. GM
- 博客尝试