SqlServer备份和恢复的方法

数据库   2024年05月09日 10:36  

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

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

域名注册
购买VPS主机

您或许对下面这些文章有兴趣:                    本月吐槽辛苦排行榜

看贴要回贴有N种理由!看帖不回贴的后果你懂得的!


评论内容 (*必填):
(Ctrl + Enter提交)   

部落快速搜索栏

各类专题梳理

网站导航栏

X
返回顶部