SQL Server如何还原误删除的数据-操作篇(二)

本文涉及的产品
云数据库 RDS SQL Server,基础系列 2核4GB
RDS SQL Server Serverless,2-4RCU 50GB 3个月
推荐场景:
日志服务 SLS,月写入数据量 50GB 1个月
简介: 我们使用的SQL Server 2017作操作平台,在数据库AdventureWorks中新建一张表并插入部分数据,然后将这些数据删除,再通过一系列的操作看是否能将这些数据恢复成我们最开始插入的数据。

三、备份事务日志

我们用【备份日志尾部】的方法来恢复刚才被删除的数据。在操作前同样需要关闭当前所有连接。

具体步骤如下:选中数据库AdventureWorks——右键【任务】——【备份】,在弹出的对话框中将备份类型选为【事务日志】,如图8:57.jpg


图8

点击左侧菜单栏的【介质选项】,做如图9的配置,在点击确定之前请再次确认是否有用户连接当前数据库,本地用户请将所有使用到该数据库的页面都关闭。

58.jpg


图9

待提示备份完成后,数据库会出现【正在还原...】字样,如图10:

                                                   59.jpg


图10


四、开始还原

首先我们要还原最近完整备份的那个备份文件,由于日志备份的特性,只认最后一次备份,所以要选择最新的那次,否则还原不了。具体操作如下:

右键AdventureWorks——【任务】——【还原】——【数据库】,在弹出的界面中做如图11的配置,只勾选组件为数据库的那个备份文件。

60.jpg

图11

点击左侧菜单栏【选项】做图12的配置,将恢复状态改完【RESTORE WITH NORECOVERY】:


61.jpg


图12

点击确定后待数据库还原成功即可进行下一步操作。


刚才我们已经还原了数据文件,下面我们继续还原日志文件。操作如下:

右键AdventureWorks——【任务】——【还原】——【事务日志】,按图13作如下配置:


62.jpg


图13

我们是在16:09分删除数据的,将时间点提前一分钟到16:08分。这里不用太在意,只要把时间点指定到你误删除的时间之前即可。


由于日志尾部备份都是最后一个备份文件,所以这里菜单栏的【选项】部分请按如图14做配置:



64.jpg

图14

待一切检查就绪后,点击确定即可开始回滚未提交的事务日志了。


五、检查是否恢复成功

输入查询语句,查询TEST中的数据。

USE  AdventureWorks
GO
SELECT * FROM TEST

结果如图15

                                                 65.jpg

图15

可以看到正是我们刚才删除前的数据。至此,整个被删除的数据即完全恢复了。


六、方法局限性

此方法有一定的局限性

首先,就是要求数据的恢复模式是【完整】的,如果之前一直是【简单】模式,此方法不适用

其次,需要有一次完整的备份文件,如果你是管理数据库的,请做好每周一次完整备份的策略。

再次,如果你发现误操作以后还有很多人做了操作,那么你还原成功后,别人的操作就会冲掉,所以发生误操作后,要马上停止别人对数据库的操作。

最后,这个方法要对数据库独占,所以你想偷偷恢复是不行的了,勇敢承认错误吧。


PS:以上操作均是实验截图,请严格按照指引操作!


相关实践学习
使用SQL语句管理索引
本次实验主要介绍如何在RDS-SQLServer数据库中,使用SQL语句管理索引。
SQL Server on Linux入门教程
SQL Server数据库一直只提供Windows下的版本。2016年微软宣布推出可运行在Linux系统下的SQL Server数据库,该版本目前还是早期预览版本。本课程主要介绍SQLServer On Linux的基本知识。 相关的阿里云产品:云数据库RDS SQL Server版 RDS SQL Server不仅拥有高可用架构和任意时间点的数据恢复功能,强力支撑各种企业应用,同时也包含了微软的License费用,减少额外支出。 了解产品详情: https://www.aliyun.com/product/rds/sqlserver
相关文章
|
2月前
|
SQL 存储 缓存
SQL Server 数据太多如何优化
11种优化方案供你参考,优化 SQL Server 数据库性能得从多个方面着手,包括硬件配置、数据库结构、查询优化、索引管理、分区分表、并行处理等。通过合理的索引、查询优化、数据分区等技术,可以在数据量增大时保持较好的性能。同时,定期进行数据库维护和清理,保证数据库高效运行。
100 4
|
3月前
|
SQL 移动开发 Oracle
SQL语句实现查询连续六天数据的方法与技巧
在数据库查询中,有时需要筛选出符合特定时间连续性条件的数据记录
|
3月前
|
SQL 存储 关系型数据库
添加数据到数据库的SQL语句详解与实践技巧
在数据库管理中,添加数据是一个基本操作,它涉及到向表中插入新的记录
|
3月前
|
SQL 数据挖掘 数据库
SQL查询每秒的数据:技巧、方法与性能优化
id="">SQL查询功能详解 SQL(Structured Query Language,结构化查询语言)是一种专门用于与数据库进行沟通和操作的语言
|
3月前
|
SQL 监控 数据处理
SQL数据库数据修改操作详解
数据库是现代信息系统的重要组成部分,其中SQL(StructuredQueryLanguage)是管理和处理数据库的重要工具之一。在日常的业务运营过程中,数据的准确性和及时性对企业来说至关重要,这就需要掌握如何在数据库中正确地进行数据修改操作。本文将详细介绍在SQL数据库中如何修改数据,帮助读者更好
683 4
|
3月前
|
SQL 关系型数据库 MySQL
SQL批量插入测试数据的几种方法?
SQL批量插入测试数据的几种方法?
317 1
|
3月前
|
SQL 分布式计算 关系型数据库
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-24 Sqoop迁移 MySQL到Hive 与 Hive到MySQL SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
153 0
|
3月前
|
SQL 分布式计算 关系型数据库
Hadoop-23 Sqoop 数据MySQL到HDFS(部分) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-23 Sqoop 数据MySQL到HDFS(部分) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
66 0
|
3月前
|
SQL 分布式计算 关系型数据库
Hadoop-22 Sqoop 数据MySQL到HDFS(全量) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
Hadoop-22 Sqoop 数据MySQL到HDFS(全量) SQL生成数据 HDFS集群 Sqoop import jdbc ETL MapReduce
86 0
|
3月前
|
SQL
使用SQL进行集合查询和数据维护
使用SQL进行集合查询和数据维护
58 0