怎么防止数据库误删除?怎么恢复数据库???

lwl0376 2008-09-18 08:37:45
昨天一不小心写了一个很傻很天真的语句,update hm_employees set name=ltrim(rtrim(idcardid))
我本来是想这样的update hm_employees set name=ltrim(rtrim(name))
结果姓名全部变成了身份证号码。
正当我想用log explorer恢复数据时(不会用),猛然发现我修改的是本机数据库并不是服务器上的数据库(我开了多个窗口,晕了),逃过一劫

这次是侥幸过去了,那以后呢,
我想问,怎么有效的防止数据库误删除误修改?一旦删除了怎么恢复数据库?多谢!!
...全文
1354 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
utpcb 2008-09-18
  • 打赏
  • 举报
回复
如果你有两个!数据库也可以直接DTS 或者UPDATE 更新咯
水族杰纶 2008-09-18
  • 打赏
  • 举报
回复
[Quote=引用 5 楼 wufeng4552 的回复:]
首先来看一下界面:

输入服务器地址,用户名及密码后点Connect,进入到下面的界面:

在这里选择要恢复数据的数据库,选择Use On-line Log(如果你又备份文件的话就不需要用这个工具了,直接用SQL搞定了)。然后点Attach,进入下面的界面:

可以看到左边菜单中有很多功能,我们要恢复数据,首先要查看日志,找出我们误操作的那些日志记录,点Browse下的View Log:
http://album.hi.csdn.net/views/photo/218750

[/Quote]
發圖不成功,參考~~
http://www.stubc.com/viewthread.php?tid=2488&extra=page%3D1&frombbs=1
dawugui 2008-09-18
  • 打赏
  • 举报
回复
误删除,没法避免.

使用Log Explorer恢复数据

http://www.ttdown.com/SoftDown.asp?ID=14562
http://js.fixdown.com/soft/8324.htm
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 for SQL Server v3.3 特别版
www.chinaz.com


Log Explorer is the leading transaction analysis and data recovery solution for Microsoft SQL Server. By providing unprecedented access to the SQL Server transaction log, Log Explorer gives you the ability to understand and solve elusive database problems by browsing the transaction log, exporting data to create reports, and selectively recovering modified, deleted, dropped, or truncated data.


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

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

右键log记录 undo transation-> 选择保存文件名和路径-> 然后打开该文件到查询分析器里执行T-sql代码。。。

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中修改的日志记录,所以无法做恢复.

--------------------------------------------------------------------------------
系统中有一个数据库DB1,系统正在使用的过程中,不小心删除了某表T1的数据
现我可以按照用完整备份文件加日志备份时间点TIME1恢复的方法来恢复该数据库

但问题出在该数据库一直还必须在使用中,所以除了你删除了数据的TA表外,其它的
表的数据你不能只是恢复到错误时间点TIME1处,因为,TIME1以后也有数据变化

解决这个问题有两个方法
1:用LOG EXEPLORE 可以轻松搞定

2:先建立一个数据库DB2,将完整备份文件恢复到DB2中,再用DB2中的T1数据来更新
DB1中的T1数据即可.


--查看备份信息
RESTORE FILELISTONLY FROM DISK = 'C:\Program Files\Microsoft SQL Server\MSSQL\BACKUP\db1_backup '

--还原旧的备份
RESTORE DATABASE db2 FROM DISK = 'C:\Program Files\Microsoft SQL Server\MSSQL\BACKUP\db1_backup ' with replace,norecovery,
move 'db1_Data ' to 'C:\Program Files\Microsoft SQL Server\MSSQL\data\db2_data.mdf ',
move 'db1_Log ' to 'C:\Program Files\Microsoft SQL Server\MSSQL\data\db2_log.ldf '

--还原数据日志到时间点
restore log db2 from disk= 'db_log_backup ' with stopat= '2003/4/22 9:57 '
lxuan_025 2008-09-18
  • 打赏
  • 举报
回复


日志 加 备份
水族杰纶 2008-09-18
  • 打赏
  • 举报
回复
首先来看一下界面:

输入服务器地址,用户名及密码后点Connect,进入到下面的界面:

在这里选择要恢复数据的数据库,选择Use On-line Log(如果你又备份文件的话就不需要用这个工具了,直接用SQL搞定了)。然后点Attach,进入下面的界面:

可以看到左边菜单中有很多功能,我们要恢复数据,首先要查看日志,找出我们误操作的那些日志记录,点Browse下的View Log:
http://album.hi.csdn.net/views/photo/218750
这样我们能看到对于这个数据库的所有操作日志,我们可以根据日期等条件来过滤出我们需要的:

过滤日志之后,就该到导出数据这一步了,这个工具提供了两种方式,第一是导出到XML或HTML文件中(对应左边菜单中的Export To File),第二是直接在数据库中建新表,然后将数据导入(Export To SQL)。
我们来看一下导入到SQL的情况,首先点Export To SQL选项:

输入Database及Table的名称,然后Finish。
这样在你数据的数据库中就会看到有这样几个表:
TestTable
TestTable_dll
TestTable_details
TestTable_Keys
TestTable_Login

其中恢复的数据就在TestTable_details表中,不过数据格式已经变了,你还需要写存储过程或用其它方法把它导入到原来的表中。
一品梅 2008-09-18
  • 打赏
  • 举报
回复
备份比较简单些.
ruihuahan 2008-09-18
  • 打赏
  • 举报
回复
小心操作,每天全备,完整恢复模式,出错后及时做日志备份。
hyde100 2008-09-18
  • 打赏
  • 举报
回复
SQL Server 2005备份方式:
1)完整备份
2)差异备份
3)日志备份
4)文件和文件组备份

SQL Server 2005恢复模式:
1)简单恢复模式
2)完整恢复模式
3)大容量日志恢复模式
hyde100 2008-09-18
  • 打赏
  • 举报
回复
怎么有效的防止数据库误删除误修改?
--------------------------------
设置有效的备份策略

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧