关于数据库操作日志,高分求助

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

谢谢指教

8 个解决方案

#1


有,肯定有.还有高手把日志打开了一条一条的看.
但具体怎么搞,我不知道.帮顶.

#2


如果数据库的恢复模型是完全,那么这些操作都被记录在数据库日志中,直至日志被截断。

想查看数据库日志,可以借助第三方日志分析和恢复软件Log Explorer

#3


用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


子陌红尘兄弟说的查看日志工具,那是否我对数据库的每一个操作已经被sqlserver记录在日志中了呢?关键我是要它记录操作的sql语句.我知道oracle有这功能,不知道sqlserver如果要实现需要我自己配置什么东西吗

#5


当然,Select这样的操作是不会记录的。

#6


Log Explorer是比较好的了

#7


用log exploer可以看到日志详细信息,但能不能看到语句,还没看到这一功能.
  remark
  up

#8


关注!

#1


有,肯定有.还有高手把日志打开了一条一条的看.
但具体怎么搞,我不知道.帮顶.

#2


如果数据库的恢复模型是完全,那么这些操作都被记录在数据库日志中,直至日志被截断。

想查看数据库日志,可以借助第三方日志分析和恢复软件Log Explorer

#3


用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


子陌红尘兄弟说的查看日志工具,那是否我对数据库的每一个操作已经被sqlserver记录在日志中了呢?关键我是要它记录操作的sql语句.我知道oracle有这功能,不知道sqlserver如果要实现需要我自己配置什么东西吗

#5


当然,Select这样的操作是不会记录的。

#6


Log Explorer是比较好的了

#7


用log exploer可以看到日志详细信息,但能不能看到语句,还没看到这一功能.
  remark
  up

#8


关注!