怎样得到SQL表的最后修改日期?

时间:2022-12-12 22:56:03
   在企业管理器中查看表时,只有名称、所有者、类型和创建日期这几项。当输入数据后看不出是哪天输入的,问:怎样才能获取所有表的修改日期?另外,怎样判断一个表是否是空表?

9 个解决方案

#1


引用楼主 zyyby6503 的帖子:
另外,怎样判断一个表是否是空表?




另外,怎样判断一个表是否是空表?
declare @cnt as int
select @cnt = count(*) from tb 
if @cnt = 0
   print '空表'
else
   print '非空表'

#2


引用楼主 zyyby6503 的帖子:
  在企业管理器中查看表时,只有名称、所有者、类型和创建日期这几项。当输入数据后看不出是哪天输入的,问:怎样才能获取所有表的修改日期?


这个貌似做不到,除非你在表中加个字段来保存更改数据的时间.

#3


你试试log explorer能否查询到修改数据的时间.


我想记录对表的添加,修改日志,不仅仅记录某个表的某项记录增加或者修改了,还有记录它的sql语句,以便以后出问题了检查,请问sqlserver有这种功能吗?怎么实现,谢谢(不是在应用程序中编程实现)

谢谢指教





用Log Explorer

Log Explorer

http://www.ttdown.com/SoftDown.asp?ID=14562
http://www.yiii.net/app/servlet/net.yiii.club.DownloadServlet?Information_Id=I00023471
解压缩密码 www.heibai.net

http://www.ttdown.com/softview_8647.htm


注册机产生的是注册码,是两个

用解压缩密码解开后,压缩包里也有一个注册机的

打开log explorer file=>attach log file->选择服务器和登陆方式->connect->
选择数据库->attach->左面对话框中browse->view log->就可以看到log记录了
想恢复的话: 右键log记录 undo transation->选择保存文件名和路径->然后打开该文件到查询分析器里执行
T-sql代码就可以了

例如 如果log是delete table where ...的话,生成的文件代码就是insert table ....

log explorer使用的几个问题

1)对数据库做了完全 差异 和日志备份
备份时选用了删除事务日志中不活动的条目
再用Log explorer打试图看日志时
提示No log recorders found that match the filter,would you like to view unfiltered data
选择yes 就看不到刚才的记录了


如果不选用了删除事务日志中不活动的条目
再用Log explorer打试图看日志时,就能看到原来的日志

2)修改了其中一个表中的部分数据,此时用Log explorer看日志,可以作日志恢复

3)然后恢复备份,(注意:恢复是断开log explorer与数据库的连接,或连接到其他数据上,
否则会出现数据库正在使用无法恢复)
恢复完后,再打开log explorer 提示No log recorders found that match the filter,would you like to view unfiltered data
选择yes 就看不到刚才在2中修改的日志记录,所以无法做恢复.


3)
不要用SQL的备份功能备份,搞不好你的日志就破坏了.

正确的备份方法是:
停止SQL服务,复制数据文件及日志文件进行文件备份.

然后启动SQL服务,用log explorer恢复数据



#4


当输入数据后看不出是哪天输入的 可以在表里面增加一列修改日期,事实写入

怎样判断一个表是否是空表
select count(1) from tabel

count(1) 是0 就是空呗

#5


引用楼主 zyyby6503 的帖子:
在企业管理器中查看表时,只有名称、所有者、类型和创建日期这几项。当输入数据后看不出是哪天输入的,问:怎样才能获取所有表的修改日期?另外,怎样判断一个表是否是空表?


1
系统里,“表的修改日期”指的表结构的修改日期,可以从系统表里查到
你的意思是要看数据修改的最后日期,只能看日志了,或者用触发器去记录。

2
if exists(select 1 from 表)
  print '不为空'
else
  print '空'

或者直接从sysindexs查。rowcnt

if exists(select 1 from sysindexes where id=object_Id('表名','u') and rowcnt>0)
  print '不为空'
else
  print '空'

#6


在企业管理器中应该不能获得表的修改日期

#7


不好意思,我的意思没表达清楚。我的意思是,进入企业管理器后,选择“表”后,我想在右边的列表中,要一眼能看出哪些表有数据,哪些表是空表,若有数据,则最后一次添加或修改的日期是哪一天?

#8


declare @a int
select @a=count(*) from tab
if @a=0
print "空表"
else
print "非空表"

#9


怎样得到SQL表的最后修改日期?

#1


引用楼主 zyyby6503 的帖子:
另外,怎样判断一个表是否是空表?




另外,怎样判断一个表是否是空表?
declare @cnt as int
select @cnt = count(*) from tb 
if @cnt = 0
   print '空表'
else
   print '非空表'

#2


引用楼主 zyyby6503 的帖子:
  在企业管理器中查看表时,只有名称、所有者、类型和创建日期这几项。当输入数据后看不出是哪天输入的,问:怎样才能获取所有表的修改日期?


这个貌似做不到,除非你在表中加个字段来保存更改数据的时间.

#3


你试试log explorer能否查询到修改数据的时间.


我想记录对表的添加,修改日志,不仅仅记录某个表的某项记录增加或者修改了,还有记录它的sql语句,以便以后出问题了检查,请问sqlserver有这种功能吗?怎么实现,谢谢(不是在应用程序中编程实现)

谢谢指教





用Log Explorer

Log Explorer

http://www.ttdown.com/SoftDown.asp?ID=14562
http://www.yiii.net/app/servlet/net.yiii.club.DownloadServlet?Information_Id=I00023471
解压缩密码 www.heibai.net

http://www.ttdown.com/softview_8647.htm


注册机产生的是注册码,是两个

用解压缩密码解开后,压缩包里也有一个注册机的

打开log explorer file=>attach log file->选择服务器和登陆方式->connect->
选择数据库->attach->左面对话框中browse->view log->就可以看到log记录了
想恢复的话: 右键log记录 undo transation->选择保存文件名和路径->然后打开该文件到查询分析器里执行
T-sql代码就可以了

例如 如果log是delete table where ...的话,生成的文件代码就是insert table ....

log explorer使用的几个问题

1)对数据库做了完全 差异 和日志备份
备份时选用了删除事务日志中不活动的条目
再用Log explorer打试图看日志时
提示No log recorders found that match the filter,would you like to view unfiltered data
选择yes 就看不到刚才的记录了


如果不选用了删除事务日志中不活动的条目
再用Log explorer打试图看日志时,就能看到原来的日志

2)修改了其中一个表中的部分数据,此时用Log explorer看日志,可以作日志恢复

3)然后恢复备份,(注意:恢复是断开log explorer与数据库的连接,或连接到其他数据上,
否则会出现数据库正在使用无法恢复)
恢复完后,再打开log explorer 提示No log recorders found that match the filter,would you like to view unfiltered data
选择yes 就看不到刚才在2中修改的日志记录,所以无法做恢复.


3)
不要用SQL的备份功能备份,搞不好你的日志就破坏了.

正确的备份方法是:
停止SQL服务,复制数据文件及日志文件进行文件备份.

然后启动SQL服务,用log explorer恢复数据



#4


当输入数据后看不出是哪天输入的 可以在表里面增加一列修改日期,事实写入

怎样判断一个表是否是空表
select count(1) from tabel

count(1) 是0 就是空呗

#5


引用楼主 zyyby6503 的帖子:
在企业管理器中查看表时,只有名称、所有者、类型和创建日期这几项。当输入数据后看不出是哪天输入的,问:怎样才能获取所有表的修改日期?另外,怎样判断一个表是否是空表?


1
系统里,“表的修改日期”指的表结构的修改日期,可以从系统表里查到
你的意思是要看数据修改的最后日期,只能看日志了,或者用触发器去记录。

2
if exists(select 1 from 表)
  print '不为空'
else
  print '空'

或者直接从sysindexs查。rowcnt

if exists(select 1 from sysindexes where id=object_Id('表名','u') and rowcnt>0)
  print '不为空'
else
  print '空'

#6


在企业管理器中应该不能获得表的修改日期

#7


不好意思,我的意思没表达清楚。我的意思是,进入企业管理器后,选择“表”后,我想在右边的列表中,要一眼能看出哪些表有数据,哪些表是空表,若有数据,则最后一次添加或修改的日期是哪一天?

#8


declare @a int
select @a=count(*) from tab
if @a=0
print "空表"
else
print "非空表"

#9


怎样得到SQL表的最后修改日期?