批量还原数据库 SQL Server 2008
1.如果你够懒,不想一步一步点路径,一步一步选择
2.如果你连单个备份数据库的存储过程都不想多执行,一般每还原一个需要修改数据库名
下面的脚本适合你:
/**********************************************
Description:This script help you restore database batch.
Pay attention:You'd better name the database like databaseName+number.
The database name is nessasery. This script not perfect,and please make it progress if you want. Author:jiangxiaoqaing
Script Date:2013-09-29
Modify history: **********************************************/ ALTER procedure [dbo].[sp_restoreDBBatch]
--The path your .bak file store
@database_bak_path varchar(200),
--The distination you want your database file store
@database_path varchar(200)
as
begin
declare @bak_databaseName varchar(200),
@DynamicSql varchar(500)=null /*Judge the '#tmpTable' object if exists,the #tmpTable store backup
database name and path*/
if (OBJECT_ID('#tmpTable') is not null)
drop table #tmpTable
create table #tmpTable
(
DBName varchar(200)
) /*using extended procedure xp_cmdshell to get the path and name*/
set @DynamicSql='cd /d "'+@database_bak_path+'"&&dir /a /b /s *.bak'
insert into #tmpTable exec xp_cmdshell @DynamicSql /*If the backup path not exists,make the directory*/
set @DynamicSql='if not exist '+@database_path+' mkdir '+@database_path+''
exec xp_cmdshell @DynamicSql declare bak_DBPathandName cursor
for
select DBName from #tmpTable
open bak_DBPathandName
while @@FETCH_STATUS=0
begin
fetch next from bak_DBPathandName into @bak_databaseName
declare @s varchar(200)
/*Get the database backup file name,store your specify path*/
set @s= reverse(substring(reverse(@bak_databaseName),0,CHARINDEX('\',reverse(@bak_databaseName))))
/*To get the database name,and tick the number*/
BEGIN
WHILE PATINDEX('%[0-9]%',@S) > 0
BEGIN
set @s=stuff(@s,patindex('%[0-9]%',@s),1,'')
end
/*Tick the '.bak' affix*/
set @s=replace(@s,'.bak','')
end
/*Backup single database*/
exec restore_database_proc @bak_databaseName,@s,@database_path
end
close reachDBName
deallocate reachDBName
end
Resore single DB:
/*******************************************
Descript:SQL server 2008 backup database.
Author:jiangxiaoqiang
Date:2013-09-26
Modify history: *******************************************/ ALTER PROCEDURE [dbo].[restore_database_proc]
@database_bak_path varchar(100),--bak file store path
@database_name varchar(100),--The new database name(Not a LogicalName and PhysicalName)
@database_path varchar(200)--restore new database file store path,the path you want to store data file
AS
--exec( 'RESTORE FILELISTONLY FROM DISK = N''' + @database_bak_path + '''')
--select * from tempdb..sysobjects where name ='#tmp_file'
if OBJECT_ID('tempdb..#tmp_file') is not null
DROP TABLE #tmp_file create table #tmp_file
(
LogicalName nvarchar(128),
PhysicalName nvarchar(260),
Type char(1),
FileGroupName nvarchar(128),
Size numeric(20,0),
MaxSize numeric(20,0),
FileId bigint,
CreateLSN numeric(25,0),
DropLSN numeric(25,0) NULL,
UniqueID uniqueidentifier,
ReadOnlyLSN numeric(25,0) NULL,
ReadWriteLSN numeric(25,0) NULL,
BackupSizeInBytes bigint,
SourceBlockSize int,
FileGroupID int,
LogGroupGUID uniqueidentifier NULL,
DifferentialBaseLSN numeric(25,0) NULL,
DifferentialBaseGUID uniqueidentifier,
IsReadOnly bit,
IsPresent bit,
TDEThumbprint varbinary(32)
)
--Database datafile full path
declare @database_mdf_path varchar(1000)
--Database log file full path
declare @database_log_path varchar(1000) --The old database name
declare @database_mdf_oldname varchar(1000)
--The old database old log name
declare @database_log_oldname varchar(1000) set @database_mdf_path = @database_path + '/' + @database_name + '.mdf'
set @database_log_path = @database_path + '/' + @database_name + '_Log.ldf' --INSERT INTO #tmp_file EXEC ('restore_database_proc N''' + @database_bak_path + '''')
INSERT INTO #tmp_file EXEC ('RESTORE FILELISTONLY FROM DISK = N''' + @database_bak_path + '''')
set @database_mdf_oldname = (select LogicalName from #tmp_file where Type = 'D')
set @database_log_oldname = (select LogicalName from #tmp_file where Type = 'L')
--select @database_mdf_oldname=LogicalName from #tmp_file where Type = 'D' --select @database_log_oldname =LogicalName from #tmp_file where Type = 'L'
exec(
'
RESTORE DATABASE ' + @database_name +
'
FROM DISK = ''' + @database_bak_path + '''' +
'
WITH
MOVE ''' + @database_mdf_oldname + ''' TO ''' + @database_mdf_path + ''',' +
'
MOVE ''' + @database_log_oldname + ''' TO ''' + @database_log_path + ''''
)
批量还原数据库 SQL Server 2008的更多相关文章
- 备份数据库SQL Server 2008下实测
下面的存储过程适用: 1.一次想备份多个数据库. 2.只需要一步操作,在有存储过程的条件下. 3.可以根据自己的需要修改存储过程. /*----------------------------- De ...
- 九、数据库——sql server 2008导入excel
昨天分配给我一个活,让我手动录入新闻网页的数据,包括每条新闻的标题.时间和链接. 一开始,就是按照最原始的手动录入的方法,一条条的录入.发现这简直就是在浪费时间,于是就想了一种新方法. 1.将网页中的 ...
- excel批量导入数据库SQL server
思路: 第一是文件上传,可以参照Jakarta的FileUpload组件,用普通的Post也就行了.第二是Excel解析,用JSL或者POI都行第三是数据保存,这个应该简单吧,一个循环,一行对应一条数 ...
- 从远程服务器数据库中同步数据到本地数据库 sql server 2008 开启分布
控制面板\所有控制面板项\管理工具 打开“管理工具――组件服务”,以此打开“组件服务――计算机”,在“我的电脑”上点击右键.在MSDTC选项卡中,点击“安全配置”按钮. 在安全配置窗口中做如下设置: ...
- SQL Server 2008 R2 数据库安装
操作系统 Windows server 2008 R2 数据库 SQL Server 2008 R2 注意:SQL Server 2008 R2需要操作系统首先安装.NET Frame ...
- .Net EF Core数据库使用SQL server 2008 R2分页报错How to avoid the “Incorrect syntax near 'OFFSET'. Invalid usage of the option NEXT in the FETCH statement.”
一. 问题说明 最近.Net EF core 程序部署到服务器,服务器数据库安装的是SQL server 2008 R2,我本地用的的是SQL server 2014,在用到分页查询时报错如下: H ...
- Vcenter虚拟化三部曲----SQL Server 2008 R2 数据库安装
操作系统 Windows server 2008 R2 数据库 SQL Server 2008 R2 注意:SQL Server 2008 R2需要操作系统首先安装.NET Frame ...
- .NET Core EF框架使用SQL server 2008数据库分页问题:Incorrect syntax near 'OFFSET'. Invalid usage of the option NEXT in the FETCH statement
一. 问题 最近.Net Core程序部署到服务器,采用EF6.本地数据库是SQL server 2016,服务器数据库安装的是SQL server 2008 R2,在用到分页查询时报错如下: { & ...
- sql server ------创建本地数据库 SQL Server 排序规则
sql server完整复制数据库 sql server导入导出方法 SQL Server 排序规则
随机推荐
- 怎么批量修改Word表格的宽度
怎么批量修改Word表格的宽度 怎么批量修改Word表格的宽度呢.Word表格可根据窗口自动调整表格宽度,使得所有的表格宽度和页面宽度一样.当页面设置了新的页边距后,所有的表格都需要调整新的宽度.或者 ...
- Highcharts axja 获取json对象动态生成报表生成
最近做个项目,项目经理想做一个统计报表,在网上查看些资料就选用Highchars 这里和大家分享下使用心得. 重点说明此代码是针对一个报表显示多个项对比显示. 直接贴代码:web端 <scrip ...
- python 调用 C++ code
本文以实例code讲解python 调用 C++的方法. 1. 如果没有参数传递从python传递至C++,python调用C++的最简单方法是将函数声明为C可用函数,然后作为C code被pytho ...
- HDU 4000 Fruit Ninja 树状数组 + 计数
给你N的一个排列,求满足:a[i] < a[k] < a[j] 并且i < j < k的三元组有多少个. 一步转化: 求出所有满足 a[i] < a[k] < a[ ...
- Crypto API加密通信流程
应用程序使用Crypto API进行加密通信的一般步骤如下: 1,include wincrypt.h 2,调用CryptAcquireContext()获得某个CSP模块中的密钥容器(key con ...
- CF 314C Sereja and Subsequences(树状数组)
题目链接:http://codeforces.com/problemset/problem/314/C 题意:给定一个数列a.(1)写出a的不同的所有非下降子列:(2)定义某个子列的f值为数列中各个数 ...
- MSAA, UIA brief explanation
MSAA, UIA brief explanation 2014-07-24 Reference [1] MSAA, UIA brief explanation [2] Testing Tools [ ...
- URAL1057. Amount of Degrees(DP)
1057 简单的数位DP 刚开始全以2进制来算的 后来发现要找最接近x,y值的那个基于b进制的0,1组合 #include <iostream> #include<cstdio&g ...
- bzoj1564: [NOI2009]二叉查找树
dp. 首先这棵树是一个treap. 权值我们可以改成任意实数,所以权值只表示相互之间的大小关系,可以离散化. 树的中序遍历是肯定确定的. 用f[l][r][w]表示中序遍历为l到r,根的权值必须大于 ...
- 简单使用Junit
不需要配置,导入相应jar,然后在测试的方法上面加入注解@Test 执行的时候选择junit即可.