首页 > 代码库 > SQLserver完全、差异、日志备份与恢复命令

SQLserver完全、差异、日志备份与恢复命令

all-sql-about_bak_restore(一):


#完全备份
backup database record to disk = ‘E:\backup\record.bak‘ with retaindays=9,format,init,compression;

#差异备份
backup database record to disk=‘E:\backup\record.bak‘ with differential,retaindays=9,noformat,noinit,compression;

#日志备份
backup log record to disk = ‘E:\backup\record.bak‘ with retaindays=9,compression;


在[还原]运行前,要把数据库[多用户]模式改成[单用户]模式:
右键数据库“属性”-“选项”-“状态”-“限制访问”-把“MULTI_USER”改成“SINGLE_USER”确定,
执行以下命令:
#备份结尾日志(做数据库完全恢复之前使用,使数据库处于还原状态)
use master;backup log record to disk = ‘E:\backup\log.bak‘ with norecovery,format,init,compression;



#查看备份介质中的备份信息
restore headeronly from disk=‘E:\backup\record.bak‘;

#列出备份集中包含的文件信息
restore filelistonly from disk=‘E:\backup\record.bak‘;

#逐个恢复备份集,恢复数据库到指定时间点
restore database test from disk =‘E:\backup\record.bak‘ with file=1,norecovery;
restore database test from disk =‘E:\backup\record.bak‘ with file=2,norecovery,stopat=‘2017-01-12 05:39:31‘;
restore log test from disk =‘E:\backup\record.bak‘ with file=3,norecovery,stopat=‘2017-01-12 05:39:31‘;
restore database record with recovery;
#备份结尾日志(做数据库完全恢复之前使用,使数据库处于还原状态)
backup log record to disk = ‘E:\backup\log.bak‘ with norecovery,format,init,compression;

--清空备份记录
use msdb;
#清空指定时间点之前的备份记录
exec sp_delete_backuphistory ‘2016-1-11‘;
#清空指定数据库的备份记录
exec sp_delete_database_backuphistory ‘TEST‘;

all-sql-about_bak_restore(二):


#完全备份
backup database record to disk = ‘E:\backup\record.bak‘ with retaindays=9,format,init,compression;

#差异备份
backup database record to disk=‘E:\backup\record.bak‘ with differential,retaindays=9,noformat,noinit,compression;

#日志备份
backup log record to disk = ‘E:\backup\record.bak‘ with retaindays=9,compression;


在[还原]运行前,要把数据库[多用户]模式改成[单用户]模式:
右键数据库“属性”-“选项”-“状态”-“限制访问”-把“MULTI_USER”改成“SINGLE_USER”确定,
执行以下命令:
#备份结尾日志(做数据库完全恢复之前使用,使数据库处于还原状态)
use master;backup log record to disk = ‘E:\backup\log.bak‘ with norecovery,format,init,compression;



#查看备份介质中的备份信息
restore headeronly from disk=‘E:\backup\record.bak‘;

#列出备份集中包含的文件信息
restore filelistonly from disk=‘E:\backup\record.bak‘;

#逐个恢复备份集,恢复数据库到指定时间点
restore database test from disk =‘E:\backup\record.bak‘ with file=1,norecovery;
restore database test from disk =‘E:\backup\record.bak‘ with file=2,norecovery,stopat=‘2017-01-12 05:39:31‘;
restore log test from disk =‘E:\backup\record.bak‘ with file=3,norecovery,stopat=‘2017-01-12 05:39:31‘;
restore database record with recovery;
#备份结尾日志(做数据库完全恢复之前使用,使数据库处于还原状态)
backup log record to disk = ‘E:\backup\log.bak‘ with norecovery,format,init,compression;

--清空备份记录
use msdb;
#清空指定时间点之前的备份记录
exec sp_delete_backuphistory ‘2016-1-11‘;
#清空指定数据库的备份记录
exec sp_delete_database_backuphistory ‘TEST‘;

all-sql-about_bak_restore(三):


BACKUP DATABASE [timeRecord] TO  DISK = N‘C:\Program Files\Microsoft SQL Server\MSSQL12.FANTASY\MSSQL\Backup\timeRecord.bak‘ WITH  RETAINDAYS = 9, NOFORMAT, NOINIT,  NAME = N‘timeRecord-完整 数据库 备份‘, SKIP, NOREWIND, NOUNLOAD, COMPRESSION,  STATS = 10, CHECKSUM
GO


BACKUP DATABASE [timeRecord] TO  DISK = N‘C:\Program Files\Microsoft SQL Server\MSSQL12.FANTASY\MSSQL\Backup\timeRecord_diff.bak‘ WITH  DIFFERENTIAL ,  RETAINDAYS = 9, NOFORMAT, NOINIT,  NAME = N‘timeRecord-差异 数据库 备份‘, SKIP, NOREWIND, NOUNLOAD, COMPRESSION,  STATS = 10
GO

BACKUP LOG [timeRecord] TO  DISK = ‘C:\Program Files\Microsoft SQL Server\MSSQL12.FANTASY\MSSQL\Backup\timeRecord_log.bak‘ WITH  DESCRIPTION = ‘日志备份‘,  RETAINDAYS = 7, FORMAT, INIT,  NAME = ‘timeRecord-日志备份‘, SKIP, NOREWIND, NOUNLOAD, COMPRESSION,  STATS = 10
GO

C:\Program Files\Microsoft SQL Server\MSSQL10_50.MSSQLSERVER\MSSQL\Backup


============================

BACKUP DATABASE [timeRecord] TO  DISK = N‘C:\Program Files\Microsoft SQL Server\MSSQL12.FANTASY\MSSQL\Backup\timeRecord_diff.bak‘

WITH  RETAINDAYS = 9, NOFORMAT, NOINIT,  COMPRESSION,   DIFFERENTIAL;
GO

========================

#完全备份
backup database record to disk = ‘E:\backup\record.bak‘ with retaindays=9,format,init,compression;
#差异备份
backup database record to disk=‘E:\backup\record.bak‘ with differential,retaindays=9,noformat,noinit,compression;
#日志备份
backup log record to disk = ‘E:\backup\record.bak‘ with retaindays=9,compression;

#查看备份介质中的备份信息
restore headeronly from disk=‘E:\backup\record.bak‘;
#列出备份集中包含的文件信息
restore filelistonly from disk=‘E:\backup\record.bak‘;
 
=========================================
12号:

backup database zhaotest to disk = ‘C:\mssql\backup\zhaotest.all.1.bak‘
with retaindays=9,format,init,compression;

backup database zhaotest to disk=‘C:\mssql\backup\zhaotest.all.2.bak‘ 
with differential,retaindays=9,noformat,noinit,compression;

backup log zhaotest to disk = ‘C:\mssql\backup\zhaotest.all.3.bak‘ 
with retaindays=9,compression;
======================================================
backup database zhaotest to disk = ‘C:\mssql\backup\zhaotest.bak‘
with retaindays=9,format,init,compression;

backup database zhaotest to disk=‘C:\mssql\backup\zhaotest.all.2.bak‘ 
with differential,retaindays=9,noformat,noinit,compression;

backup log zhaotest to disk = ‘C:\mssql\backup\zhaotest.all.4.bak‘ 
with retaindays=9,compression;

restore database zhaotest from disk= ‘C:\mssql\backup\zhaotest.all.3.bak‘ 
with file=1,norecovery;

restore database zhaotest from disk=‘C:\MSSQL\Backup\zhaotest.all.2.bak‘
with file=2,norecovery,stopat=‘2017-01-12 12:23:31‘;

restore log zhaotest from disk=‘C:\MSSQL\Backup\zhaotest.all.3.bak‘
with file=3,norecovery,stopat=‘2017-01-12 19:23:21‘;

restore database zhaotest with recovery;

all-sql-about_bak_restore(四):

实验一 SQLserver完全备份,差异备份,日志备份并且恢复到指定的时间点

示例:

备份(要求在每次备份前,都要向数据库里更新数据)

技术分享

恢复到指定时间点

技术分享

要求,把操作的步骤截图,贴到下面(至少要含有备份成功,恢复成功的步骤),如果恢复遇到数据库被占用的问题,请参考附录进行解决

  

附录:

还原sql server数据库遇到如下问题

技术分享

该问题主要是你在还原的时候还有其他进程连在上面,导致无法获得独占造成的。

解决思路:

步骤

USE Master

ALTER DATABASE 数据库名称 SET OFFLINE WITH ROLLBACK IMMEDIATE

如果此时还原还是不行。可能是删完进程马上有新的进程连进来,导致一直失败。应用程序一直不停的进行数据库链接

这时,可以在单用户下还原。

设置方式:选中要还原的数据库-->属性-->选项-->限制访问

该值从MULTI_USER修改为SINGLE_USER,此时该数据库就会显示为单用户模式

这是GUI的模式,语句的办法比较简单

USE MASTER

Go

ALTER DATABASE 数据库名字 SET SINGLE_USER WITH ROLLBACK IMMEDIATE;   

GO

设置单用户数据库必须要超级用户

或者使用

删除连在上面的进程,回滚未提交的事务,然后还原。

1.查询要还原的数据库ID

Select * from master..sysdatabases where name = ‘‘;

2.获取该数据库的进程

Select * from sys.sysprocesses a where a.dbid = ‘‘;

3.杀掉连接在上面的进程

kill @spid;

 




SQLserver完全、差异、日志备份与恢复命令