我想记录对表的添加,修改日志,不仅仅记录某个表的某项记录增加或者修改了,还有记录它的sql语句,以便以后出问题了检查,请问sqlserver有这种功能吗?怎么实现,谢谢(不是在应用程序中编程实现)谢谢指教用Log ExplorerLog Explorerhttp://www.ttdown.com/SoftDown.asp?ID=14562
http://www.yiii.net/app/servlet/net.yiii.club.DownloadServlet?Information_Id=I00023471
解压缩密码 www.heibai.nethttp://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恢复数据

解决方案 »

  1.   

    USE master--创建数据库
    CREATE DATABASE db
    ON PRIMARY(
    NAME='db_data',
    FILENAME= 'c:\db_data.mdf')
    LOG ON(
    NAME='db_log',
    FILENAME ='c:\db.ldf')
    GO--创建表
    CREATE TABLE db.dbo.ta(id int)
    INSERT db.dbo.ta SELECT id FROM sysobjects
    GO
    --做文件组备份
    BACKUP DATABASE db TO DISK='c:\db.bak' WITH FORMAT--备份后,再做数据处理
    CREATE TABLE db.dbo.tb(id int)
    INSERT db.dbo.tb SELECT id FROM sysobjects
    GO/*--下面演示了破坏数据文件的处理,这些操作在操作系统中进行1. 停止SQL Server服务(msqlserver服务)
    2. 删除文件 c:\db_data.ndf (模拟破坏)
    3. 重新SQL Server服务,此时数据库DB置疑
    --*/
    GO--下面演示了如何恢复数据
    --首先要备份当前日志
    BACKUP LOG db TO DISK='c:\db_log.bak' WITH FORMAT,NO_TRUNCATE
    --利用文件组备份恢复破坏的文件
    RESTORE DATABASE db FROM DISK='c:\db.bak' WITH NORECOVERY
    --还原到日志点
    RESTORE LOG db FROM DISK='c:\db_log.bak' WITH RECOVERY
    --显示已经恢复的数据
    SELECT COUNT(*) FROM db.dbo.ta
    SELECT COUNT(*) FROM db.dbo.tb
    GO--删除测试
    DROP DATABASE db
      

  2.   

    USE master--创建并完全备份数据库
    CREATE DATABASE db
    BACKUP DATABASE db TO DISK='c:\db.bak' WITH FORMAT
    GO--标记事务处理
    BEGIN TRANSACTION Tran1 WITH MARKCREATE TABLE db.dbo.tb(id int)COMMIT TRAN Tran1--事务完成后插入数据
    INSERT db.dbo.tb SELECT id FROM sysobjects
    GO--还原数据到事务标记 Tran1 前
    BACKUP LOG db TO DISK='c:\db_log.bak' WITH FORMAT
    DROP DATABASE db
    RESTORE DATABASE db FROM DISK='c:\db.bak' WITH NORECOVERY
    RESTORE LOG db FROM DISK='c:\db_log.bak' WITH STOPBEFOREMARK='Tran1'
    SELECT COUNT(*) FROM db.dbo.tb
    /*--事务标记 Tran1 前没有创建表,所以会收到错误信息
    对象名 'db.dbo.tb' 无效。
    --*/
    GO--还原数据库到事务标记 Tran1 后
    DROP DATABASE db
    RESTORE DATABASE db FROM DISK='c:\db.bak' WITH NORECOVERY
    RESTORE LOG db FROM DISK='c:\db_log.bak' WITH STOPATMARK='Tran1'
    SELECT COUNT(*) FROM db.dbo.tb
    /*--结果
    ----------- 
    0(所影响的行数为 1 行)
    --*/
    GO--删除测试
    DROP DATABASE db
      

  3.   

    --创建测试数据库
    CREATE DATABASE Db
    GO--对数据库进行备份
    BACKUP DATABASE Db TO DISK='c:\db.bak' WITH FORMAT
    GO--创建测试表
    CREATE TABLE Db.dbo.TB_test(ID int)--延时1秒钟,再进行后面的操作(这是由于SQL Server的时间精度最大为百分之三秒,不延时的话,可能会导致还原到时间点的操作失败)
    WAITFOR DELAY '00:00:01'
    GO--假设我们现在误操作删除了 Db.dbo.TB_test 这个表
    DROP TABLE Db.dbo.TB_test--保存删除表的时间
    SELECT dt=GETDATE() INTO #
    GO--在删除操作后,发现不应该删除表 Db.dbo.TB_test--下面演示了如何恢复这个误删除的表 Db.dbo.TB_test--首先,备份事务日志(使用事务日志才能还原到指定的时间点)
    BACKUP LOG Db TO DISK='c:\db_log.bak' WITH FORMAT
    GO--接下来,我们要先还原完全备份(还原日志必须在还原完全备份的基础上进行)
    RESTORE DATABASE Db FROM DISK='c:\db.bak' WITH REPLACE,NORECOVERY
    GO--将事务日志还原到删除操作前(这里的时间对应上面的删除时间,并比删除时间略早
    DECLARE @dt datetime
    SELECT @dt=DATEADD(ms,-20,dt) FROM #  --获取比表被删除的时间略早的时间
    RESTORE LOG Db FROM DISK='c:\db_log.bak' WITH RECOVERY,STOPAT=@dt
    GO--查询一下,看表是否恢复
    SELECT * FROM Db.dbo.TB_test/*--结果:
    ID          
    ----------- (所影响的行数为 0 行)
    --*/--测试成功
    GO--最后删除我们做的测试环境
    DROP DATABASE Db
    DROP TABLE #
      

  4.   

    谢谢二位的回复!
    完全备份的数据都有在,完全备份已经恢复了,但是日志恢复的时候少了中间的几个(.trn)文件,日志恢复不了.
    请问dawugui ,log explore能不能做这样的恢复呢?
      

  5.   

    Log   Explorer 
    可以
      

  6.   

    使用Log Explorer恢复数据用日志工具Log Explorer
    步骤:
    1、查看日志
       a、打开log explorer,选择菜单File-->attach log file   
       b、在Log File Selection窗口中,填写连接到要恢复数据的数据库服务器机器名、数据库登录ID及密码,然后点击"Connect"按钮。
       c、若连接成功,则窗口左边树将显示命令菜单,这时我们点击Browser下的View Log命令,此时窗口右边则出现该数据库的Log。
    2、恢复数据库
       这时您只要选择您要恢复对事件点,右键点击选择"undo transation"命令,保存T-SQL代码,然后在查询分析器中执行该T-SQL代码
      

  7.   

    非常感谢大家的帮助.我用log explorer提供的salvage dropped/truncated
    恢复了数据,但是可能还有丢失的.已经很满足了,我都差点放弃的.谢谢大家!