文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2024-04-02 19:55

关注

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完全备份,差异备份,日志备份并且恢复到指定的时间点

示例:

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

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

恢复到指定时间点

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

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

  

附录:

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

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

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

解决思路:

步骤

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;

 




阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯