SqlServer备份和恢复的方法

本篇内容介绍了“SqlServer备份和恢复的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

成都创新互联-专业网站定制、快速模板网站建设、高性价比湖北网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式湖北网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖湖北地区。费用合理售后完善,10多年实体公司更值得信赖。

SqlServer备份和恢复

备份

---创建测试数据库chen20181123

create database chen20181123

on

(name=chen_data,

filename='D:\hrtest\DB\testdata\chen20181123_data.mdf',

size=10MB,

filegrowth=1MB)

log on

(name=chen_log,

filename='D:\hrtest\DB\testdata\chen20181123_log.ldf',

size=1MB,

filegrowth=10MB);

---创建测试数据

use chen20181123

create table t1(id int,a varchar(100));

insert into t1 values(1,'a');

insert into t1 values(2,'b');

insert into t1 values(3,'c');

---数据库全备

BACKUP DATABASE chen20181123

TO DISK='D:\hrtest\DB\testdata\backup\chen20181123_full.bak'  WITH COMPRESSION

GO

insert into t1 values(4,'d');

insert into t1 values(5,'e');

---数据库差异备份

BACKUP DATABASE chen20181123

TO DISK='D:\hrtest\DB\testdata\backup\chen20181123_1.bak'  WITH COMPRESSION,DIFFERENTIAL;

GO

insert into t1 values(7,'f');

insert into t1 values(8,'g');

---数据库日志备份

BACKUP LOG chen20181123 TO DISK='D:\hrtest\DB\testdata\backup\chen20181123_2.trn' WITH COMPRESSION;

insert into t1 values(9,'f');

insert into t1 values(10,'g');

---19:51

delete t1;

恢复场景

---恢复全备+差异备份 恢复

restore filelistonly from disk='D:\hrtest\DB\testdata\backup\chen20181123_full.bak';

RESTORE DATABASE chen20181123_1

  FROM DISK = 'D:\hrtest\DB\testdata\backup\chen20181123_full.bak'

  WITH NORECOVERY,

  MOVE 'chen_data' TO 'D:\hrtest\DB\testdata\chen20181123_1_data.mdf',  

  MOVE 'chen_log' TO 'D:\hrtest\DB\testdata\chen20181123_1_log.ldf';

RESTORE DATABASE chen20181123_1 from disk='D:\hrtest\DB\testdata\backup\chen20181123_1.bak'

  WITH RECOVERY;

select * from chen20181123_1.dbo.t1;  ---5

---恢复全备+差异备份+日志备份 恢复

USE MASTER

---drop database chen20181123_2;

RESTORE DATABASE chen20181123_2

  FROM DISK = 'D:\hrtest\DB\testdata\backup\chen20181123_full.bak'

  WITH NORECOVERY,

  MOVE 'chen_data' TO 'D:\hrtest\DB\testdata\chen20181123_2_data.mdf',  

  MOVE 'chen_log' TO 'D:\hrtest\DB\testdata\chen20181123_2_log.ldf';

RESTORE DATABASE chen20181123_2 from disk='D:\hrtest\DB\testdata\backup\chen20181123_1.bak'

  WITH NORECOVERY;

RESTORE LOG chen20181123_2 from disk='D:\hrtest\DB\testdata\backup\chen20181123_2.trn'

  WITH RECOVERY;

select * from chen20181123_2.dbo.t1;  ---7

---20:33

BACKUP LOG chen20181123 TO DISK='D:\hrtest\DB\testdata\backup\chen20181123_3.trn' WITH COMPRESSION;

---恢复全备+差异备份+日志备份+新日志备份 恢复

USE MASTER

RESTORE DATABASE chen20181123_3

  FROM DISK = 'D:\hrtest\DB\testdata\backup\chen20181123_full.bak'

  WITH NORECOVERY,

  MOVE 'chen_data' TO 'D:\hrtest\DB\testdata\chen20181123_3_data.mdf',  

  MOVE 'chen_log' TO 'D:\hrtest\DB\testdata\chen20181123_3_log.ldf';

RESTORE DATABASE chen20181123_3 from disk='D:\hrtest\DB\testdata\backup\chen20181123_1.bak'

  WITH NORECOVERY;

RESTORE LOG chen20181123_3 from disk='D:\hrtest\DB\testdata\backup\chen20181123_2.trn'

  WITH NORECOVERY;

RESTORE LOG chen20181123_3 from disk='D:\hrtest\DB\testdata\backup\chen20181123_3.trn'

  WITH RECOVERY;

select * from chen20181123_3.dbo.t1;  ---0

---恢复全备+差异备份+日志备份+新日志备份+基于时间点不完全恢复

USE MASTER

---drop database chen20181123_5;

RESTORE DATABASE chen20181123_5

  FROM DISK = 'D:\hrtest\DB\testdata\backup\chen20181123_full.bak'

  WITH NORECOVERY,

  MOVE 'chen_data' TO 'D:\hrtest\DB\testdata\chen20181123_5_data.mdf',  

  MOVE 'chen_log' TO 'D:\hrtest\DB\testdata\chen20181123_5_log.ldf';

RESTORE DATABASE chen20181123_5 from disk='D:\hrtest\DB\testdata\backup\chen20181123_1.bak'

  WITH NORECOVERY;

RESTORE LOG chen20181123_5 from disk='D:\hrtest\DB\testdata\backup\chen20181123_2.trn'

  WITH NORECOVERY;

RESTORE LOG chen20181123_5 from disk='D:\hrtest\DB\testdata\backup\chen20181123_3.trn'

  WITH RECOVERY,STOPAT='2018-11-23 19:50:00';

select * from chen20181123_5.dbo.t1;  ---9

“SqlServer备份和恢复的方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!


分享名称:SqlServer备份和恢复的方法
网页链接:http://pwwzsj.com/article/jjgegi.html