MSSQL在线文件还原脚本

在线文件还原:如果比较大的MSSQL数据库的损坏只是集中在其中某一个文件或者文件组上,使用在线文件还原技术,
只是把坏掉的数据文件或者文件组重建,能节约很多时间。
以下是测试脚本(假设损坏的文件时Trn01):

--首先还原损坏的文件Trn01(执行这一步之前,你必须取得数据库的独占访问权):
RESTORE DATABASE [AdventureWorks] FILE=N‘Trn01‘ FROM DISK=N‘D:\BACKUP_TEST\AD_FULL.BAK‘ WITH NORECOVERY,STATS=10
--如果不是企业版,将会出现错误消息 3159,提示你需要使用BACKUP LOG WITH NORECOVERY 备份尾日志,意味着您只能离线文件还原。  --BACKUP LOG [AdventureWorks] TO DISK =N‘D:\BACKUP_TEST\Log_BACK_TAIL.TRN‘ WITH NORECOVERY,COMPRESSION,STATS=10
--啰嗦一句,如果是企业版,执行完成后此时你可以放开独占访问权了。(如果是通过更改为SINGLE_USER模式的话,现在可以改为MULTI_USER放开访问了)
--但此时Trn01所属的文件组TRN不能被访问,TRN文件组以外的数据库内容可以被访问。
--如果试图访问Trn01中的表,将出现如下的错误消息:
--消息 8653,级别 16,状态 1,第 2 行
--查询处理器无法为表或视图“***”生成计划,因为该表驻留在不处于联机状态的文件组中。
--备份文件离线时点的日志:
BACKUP LOG [AdventureWorks] TO DISK =N‘D:\BACKUP_TEST\Log_BACK_TAIL.TRN‘ WITH COPY_ONLY,COMPRESSION,STATS=10
--依次还原日志:
RESTORE LOG [AdventureWorks] FROM DISK=N‘D:\BACKUP_TEST\LOG_BACK_1.TRN‘ WITH NORECOVERY,STATS=10
RESTORE LOG [AdventureWorks] FROM DISK=N‘D:\BACKUP_TEST\LOG_BACK_2.TRN‘ WITH NORECOVERY,STATS=10
--还原文件离线时点的日志:
RESTORE LOG [AdventureWorks] FROM DISK=N‘D:\BACKUP_TEST\Log_BACK_TAIL.TRN‘ WITH RECOVERY,STATS=10

MSSQL在线文件还原脚本

时间: 2024-08-29 18:45:47

MSSQL在线文件还原脚本的相关文章

mssql server 2005还原数据库bak文件与“备份集中的数据库备份与现有的xx数据库不同”解决方法

mssql server 2005还原数据库bak文件,网站使用虚拟主机建站会经常遇到,一般情况下,主机商有在线的管理程序,但有时候没有的话,就需要本地还原备份sql数据库了.这种情况mssql server 2008也同样会出现,有时候会出现“备份集中的数据库备份与现有的xx数据库不同”的错误提示,本文也一并把解决方法说道说道. 第一部分,mssql server 2005(2008)还原数据库bak文件. 一.连接上数据库,右键数据库,选择新建数据库,输入你要还原数据库的名称. 二.确定后右

MSSQL段落还原脚本

--段落还原:数据库损坏范围比较大,跨多个数据文件甚至跨文件组的时候,我们不得不恢复整个数据库.--这时如果数据库特别大,数据库恢复时间将会很长.但我们可以使用SQL Server提供的段落还原,来逐步恢复数据库. --首先备份尾日志: BACKUP LOG [AdventureWorks] TO DISK =N'D:\BACKUP_TEST\LOG_BACK_TAIL.trn' WITH NO_TRUNCATE ,NORECOVERY,COMPRESSION,STATS=10 --部分还原主文

MSSQL通用还原脚本

MSSQL还原脚本 SQL Server通用还原脚本,只需修改第二步中,需要还原的数据库名称和路径 执行完脚本后会生成对应的还原命令,直接新建查询后执行即可 -- 2 - Initialize variables SET @dbName = 'Customer' SET @backupPath = 'D:\SQLBackups\' 脚本如下: --open-- xp_cmdshell sp_configure 'show advanced options',1 reconfigure go sp

实战:INNOBACKUPEX for mysql 5.6自己主动还原脚本-v2

脚本再次更新,共享一下! #!/bin/sh # # 用法: # ./restore.sh /你备份文件的全路径 #[email protected] INNOBACKUPEX=innobackupex INNOBACKUPEX_PATH=/usr/bin/$INNOBACKUPEX TMP_LOG="/var/log/restore.$$.log" MY_CNF=/usr/local/mysql/my.cnf BACKUP_DIR=/backup # 你的备份主文件夹 FULLBAC

Linux系统备份还原脚本

\ #!/bin/sh #备份linux系统. #命令如:sh 当前脚本.sh /dev/sdax 备份文件名 #参数1:备份的盘,备份前先umount.如:/dev/sda1 #参数2:备份保存的文件名. if [ $# -ne 2 ]; then echo "请传入两个参数." exit 0 fi #当前日期,用于建立临时文件夹和备份文件. datename=`date +%Y%m%d_%H%M%S` #临时挂载的文件夹名称 tmpdir="/tmp/dir${daten

PHP-数据库备份还原脚本

PHP数据库备份.还原 1. mydb.php //DB类2. backup.php //备份脚本 3. restore.php //还原脚本 1.数据库类 <?php class db{ var $linkid; var $sqlid; var $record; function db($host="localhost",$username="root",$password="",$database="mydb") {

DB2数据库在线备份还原笔记

数据库在线增量备份    由于一般客户的生产系统数据量都很大,所以频繁的进行数据库或表空间的全量备份在空间存储上变得不可行.DB2 支持两种增量的备份,一种是增量备份(comulative backup),另一种是差异备份(deltabackup).总的说来,增量的备份(包括增量备份和差异备份),在其备份映像文件中只包含自上次进行备份以来有过更新的页,除更新的数据和索引页之外,每个增量备份映像还包含通常存储在完全备份映像中的初始数据库元数据(例如,数据库配置.表空间定义和数据库历史记录等).增量

xtrabackup自动还原脚本

xtrabackup自动还原 ************************************************************************************************ 应用场景: ************************************************************************************************ 1.备份目录为/backup/full和/backup/incre的架

xtrabackup自动还原脚本v2

xtrabackup自动还原 ************************************************************************************************ 应用场景: ************************************************************************************************ 1.备份目录为/backup/full和/backup/incre的架