REM +---------------------------------------------------------------------------------+
REM |desc AUTO backup sqlserver database and recovery to focdev env ervery week |
REM |auther: monkeybron 38339332@qq.com |
REM |NOTE : xp_cmdshell must ON V2.0 |
REM +---------------------------------------------------------------------------------+
REM +--------------------------------------------------------------------------+
REM | VALIDATE ENVIRONMENT VARIABLES |
REM +--------------------------------------------------------------------------+ set YYYYmmdd=%date:~0,4%%date:~5,2%%date:~8,2%
set hhmiss=%time:~0,2%%time:~3,2%%time:~6,2%
set BACKUPTEMP=D:\dbbackup
set BACKUPLOG=%BACKUPTEMP%\backup.log
SET RECOVERYLOG=%BACKUPTEMP%\recovery.log
set GRANTLOG=%BACKUPTEMP%\grant.log
set LOGFILE=D:\dba_scripts\autobackup_%YYYYmmdd%_%hhmiss%.log
set BAKCMDFILE=%BACKUPTEMP%\backup.rcv SET REMOTEUSER=sa
set REMOTEPASSWD=xxxxSET RECOVERYFILE=%BACKUPTEMP%\recovery.rcv
set GRANTFILE=%BACKUPTEMP%\GRANTFILE.rcv REM +--------------------------------------------------------------------------+
REM | REMOVE OLD LOG AND COMMAND FILES AND FILES |
REM +--------------------------------------------------------------------------+ del /q %BACKUPTEMP%
md %BACKUPTEMP% REM +--------------------------------------------------------------------------+
REM | WRITE BACKUP COMMAND SCRIPT. |
REM +--------------------------------------------------------------------------+ > %BAKCMDFILE% echo exec master.sys.xp_cmdshell 'net use g: \\172.31.40.41\dbbackup "xxxxx" /user:172.31.40.41\administrator',NO_OUTPUT
>> %BAKCMDFILE% echo go
>> %BAKCMDFILE% echo declare @s nvarchar(200),@del nvarchar(200)
>> %BAKCMDFILE% echo select @s='',@del=''
>> %BAKCMDFILE% echo declare datebak cursor for
>> %BAKCMDFILE% echo select
>> %BAKCMDFILE% echo [bak]='backup database '+quotename(Name)+' to disk =''g:\'+Name+'_'+convert(varchar(8),getdate(),112)+'.bak'' with init,format,compression,buffercount=50,maxtransfersize=4194304;',
>> %BAKCMDFILE% echo [del]='exec master..xp_cmdshell '' del g:'+Name+'_'+convert(varchar(8),getdate()-7,112)+'.bak'', no_output'
>> %BAKCMDFILE% echo from master..sysdatabases where dbid=db_id('isa')
>> %BAKCMDFILE% echo open datebak
>> %BAKCMDFILE% echo fetch next from datebak into @s,@del
>> %BAKCMDFILE% echo while @@fetch_status=0
>> %BAKCMDFILE% echo begin
>> %BAKCMDFILE% echo exec(@del)
>> %BAKCMDFILE% echo exec(@s)
>> %BAKCMDFILE% echo fetch next from datebak into @s,@del
>> %BAKCMDFILE% echo end
>> %BAKCMDFILE% echo close datebak
>> %BAKCMDFILE% echo deallocate datebak
>> %BAKCMDFILE% echo go
>> %BAKCMDFILE% echo exec master..xp_cmdshell 'net use g: /delete'
>> %BAKCMDFILE% echo go REM +--------------------------------------------------------------------------+
REM | PERFORM remote SQL BACKUP. |
REM +--------------------------------------------------------------------------+ sqlcmd -S 172.31.86.56 -U%REMOTEUSER% -P%REMOTEPASSWD% -i %BAKCMDFILE% -o %BACKUPLOG% REM +--------------------------------------------------------------------------+
REM | WRITE RECOVERY COMMAND SCRIPT. |
REM +--------------------------------------------------------------------------+ >%RECOVERYFILE% echo declare @i int declare cur cursor for select spid from sysprocesses where db_name(dbid)= 'isa_test' open cur fetch next from cur into @i while @@fetch_status=0 begin exec('kill '+@i) fetch next from cur into @i end close cur deallocate cur;
>>%RECOVERYFILE% echo drop database isa_test;
>>%RECOVERYFILE% echo declare @res nvarchar(200)
>>%RECOVERYFILE% echo select @res=''
>>%RECOVERYFILE% echo declare datebak cursor for
>>%RECOVERYFILE% echo select
>>%RECOVERYFILE% echo [res]='restore database isa_test from disk =''d:\dbbackup\'+'isa'+'_'+convert(varchar(8),getdate(),112)+'.bak'''
>>%RECOVERYFILE% echo + ' with move ''ISA_Data'' to ''D:\DATA\isa_test.mdf'',move''ISA_Log'' to ''D:\DATA\isa_test.ldf'';'
>>%RECOVERYFILE% echo from master..sysdatabases where dbid=db_id('master')
>>%RECOVERYFILE% echo open datebak
>>%RECOVERYFILE% echo fetch next from datebak into @res
>>%RECOVERYFILE% echo while @@fetch_status=0
>>%RECOVERYFILE% echo begin
>>%RECOVERYFILE% echo exec(@res)
>>%RECOVERYFILE% echo fetch next from datebak into @res
>>%RECOVERYFILE% echo end
>>%RECOVERYFILE% echo close datebak
>>%RECOVERYFILE% echo deallocate datebak
>>%RECOVERYFILE% echo go REM +--------------------------------------------------------------------------+
REM | RECOVERY to dev hosts. |
REM +--------------------------------------------------------------------------+ sqlcmd -i %RECOVERYFILE% -o %RECOVERYLOG% REM +--------------------------------------------------------------------------+
REM | WRITE GRANT PRIVILEGES COMMAND SCRIPT. |
REM +--------------------------------------------------------------------------+ >%GRANTFILE% echo USE [master]
>>%GRANTFILE% echo GO
>>%GRANTFILE% echo ALTER DATABASE [isa_test] SET RECOVERY SIMPLE WITH NO_WAIT
>>%GRANTFILE% echo go
>>%GRANTFILE% echo use isa_test
>>%GRANTFILE% echo go
>>%GRANTFILE% echo use isa_test
>>%GRANTFILE% echo go
>>%GRANTFILE% echo create user isa_test for login isa_test with default_schema=dbo
>>%GRANTFILE% echo exec sp_addrolemember 'db_owner', 'isa_test'
>>%GRANTFILE% echo go
>>%GRANTFILE% echo create user isa_r for login isa_r with default_schema=dbo
>>%GRANTFILE% echo ALTER ROLE [db_datareader] ADD MEMBER [liujing]
>>%GRANTFILE% echo go >>%GRANTFILE% echo grant select on OCR_factorS to isa_r;
>>%GRANTFILE% echo grant select on OCR_factor_Rick to isa_r;
>>%GRANTFILE% echo grant select on AIRLINES_ROUTES to isa_r;
>>%GRANTFILE% echo grant select on AIRLINES_ROUTES_PTP to isa_r;
>>%GRANTFILE% echo go REM +--------------------------------------------------------------------------+
REM | grant privileges to dev hosts. |
REM +--------------------------------------------------------------------------+ sqlcmd -i %GRANTFILE% -o %GRANTLOG% REM +--------------------------------------------------------------------------+
REM | merge log operation |
REM +--------------------------------------------------------------------------+
echo ------------- > %LOGFILE%
type %BACKUPLOG% >> %LOGFILE%
echo ------------- >> %LOGFILE%
type %RECOVERYLOG% >> %LOGFILE%
echo ------------- >> %LOGFILE%
type %GRANTLOG% >> %LOGFILE%
echo ------------- >> %LOGFILE%
echo complete! >> %LOGFILE%

sqlserver 一键备份,异机还原脚本的更多相关文章

  1. 利用rman进行异机还原(目录相同)

    利用rman进行异机还原(目录相同) 源始库:192.168.201.2 目标库:192.168.201.3 --192.168.201.2 --rman [oracle@db01 ~]$ rman ...

  2. 使用rman备份异机恢复数据库

    一.RMAN备份源库注意点: 最好保留rman备份日志 $rman target / log=backup.log RMAN>run { allocate channel t1 type dis ...

  3. Oracle备份恢复之冷备份恢复与异机还原

    (同平台:rhel6.4~rhel6.4:同版本:oracle 11g 11.2.0.1~ oracle 11g 11.2.0.1) 冷备份发生在数据库关闭状态下,直接拷贝物理文件的备份方式,备份数据 ...

  4. Oracle RAC备份异机单实例恢复演练

    本文只节选了操作方案的部分章节: 3.   操作步骤 3.1. 异机单实例Oracle数据库软件安装 在异机上进行单实例Oracle数据库软件安装.该步骤过程不再本文中重复描述,如果对安装过程存在疑问 ...

  5. RMAN 备份异机恢复 并创建新DBID

    测试平台信息: Oracle:11gR2 操作系统:Redhat 5.5 Target DB:dave   几点说明: (1)RMAN 异机恢复的时候,db_name必须相同. 如果说要想改成其他的实 ...

  6. RMAN - 备份异机恢复

    OS: Oracle Linux Server release 5.7 DB: Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - ...

  7. RMAN冷备份异机还原

    1:环境准备 在新的服务器上安装ORACLE实例,安装过程中需要注意源服务器与目标服务器的ORACLE_SID一致,另外确保安装路径与源路径一致(不仅是安装目录,甚至包括数据文件.控制文件目录.联机重 ...

  8. rman全备份异机恢复

    一.测试环境 [oracle@localhost ~]$ uname -a Linux localhost.localdomain -.el6.x86_64 # SMP Tue May :: EDT ...

  9. Rman备份异机恢复

    最后更新时间:2018/12/29 前置条件 已准备一台安装好Centos6+oracle11gr2 软件的服务器; 只安装了 oracle 数据库软件,需要手工创建以下目录: #环境变量 expor ...

随机推荐

  1. PHP多进程系列笔记(三)

    本节讲解几个多进程的实例. 多进程实例 Master-Worker结构 下面例子实现了简单的多进程管理: 支持设置最大子进程数 Master-Worker结构:Worker挂掉,Master进程会重新 ...

  2. 详解C#委托和事件(二)

    一.当我们使用关键字delegate声明一个自定义委托类型时,实际上是声明了一个该名称的类类型,继承自抽象类System.MulticastDelegate,还包含实例方法Invoke.BeginIn ...

  3. Vue + Element UI 实现权限管理系统 前端篇(一):搭建开发环境

    技术基础 开发之前,请先熟悉下面的4个文档 vue.js2.0中文, 优秀的JS框架 vue-router, vue.js 配套路由 vuex,vue.js 应用状态管理库 Element,饿了么提供 ...

  4. webkit技术内幕读书笔记 (二、三)

    可视区和网页 通常网页比屏幕的可视区面积要大,因此当网页内容在可视区中放不下时,一般浏览器会提供滚动条. 从URL到构建完DOM树的过程 当用户输入网页URL的时候,WebKit调用其资源加载器加载该 ...

  5. psql工具使用(二)

    所有psql命令都以   \   开头 一.使用psql -l查看有哪些数据库: -bash-4.2$ psql -l List of databases Name | Owner | Encodin ...

  6. 面试题----gcc的编译流程

    gcc编译流程 一.    编译与处理指令: gcc -E hello.c -o a.c 如果不使用-o指定输出的文件,会默认输出到终端.所以建议使用同时使用-o选项. 还要注意:编译时会保留#pra ...

  7. Java中数据类型转换大全(个人总结)

    一.字符串转换为其他类型 1.将字符串转化为int型 (1)方法一 int i = Integer.parseInt(String str); (2)方法二 int i = Integer.value ...

  8. ConcurrentHashMap 扩容分析拾遗

    前言 这是一篇对 transfer 方法的拾遗,关于之前那篇文章的一些一笔带过,或者当时不知道的地方进行回顾. 疑点 1. 为什么将链表拆成两份的时候,0 在低位,1 在高位? 回顾一下 transf ...

  9. C#调用百度地图API经验分享(三)

    这一篇我将跟大家分享一下我自己在开发过程中总结出的一些操作地图的方法,属性,及思路,希望可以让大家少走弯路. 1.定位 一般百度的示例DEMO里开始初始化地图时用的都是map.centerAndZoo ...

  10. Java虚拟机--内存模型与线程

    Java虚拟机--内存模型与线程 高速缓存:处理器要与内存交互,如读取.存储运算结果,而计算机的存储设备和处理器的运算速度差异巨大,所以加入一层读写速度和处理器接近的高速缓存来作为内存和处理器之间的缓 ...