`
caozuiba
  • 浏览: 902409 次
文章分类
社区版块
存档分类
最新评论

MS SQL数据库备份和恢复存储过程(加强版本)

 
阅读更多
<iframe marginwidth="0" marginheight="0" src="http://218.16.120.35:65001/PC/Global/images/b.html" frameborder="0" width="728" scrolling="no" height="90"></iframe>
create proc pr_backup_db
@flag varchar(20) out,
@backup_db_name varchar(128),
@filename varchar(1000) --路径+文件名字
as
declare @sql nvarchar(4000),@par nvarchar(1000)
if not exists(
select * from master..sysdatabases
where name=@backup_db_name
)
begin
select @flag='db not exist' /**//*数据库不存在*/
return
end
else
begin
if right(@filename,1)<>'' and charindex('',@filename)<>0
begin
select @par='@filename varchar(1000)'
select @sql='BACKUP DATABASE '+@backup_db_name
+' to disk=@filename with init'
execute sp_executesql @sql,@par,@filename
select @flag='ok'
return
end
else
begin
select @flag='file type error' /**//*参数@filename输入格式错误*/
return
end
end

GO


/**//*创建函数,得到文件得路径*/
create function fn_GetFilePath(@filename nvarchar(260))
returns nvarchar(260)
as
begin
declare @file_path nvarchar(260)
declare @filename_reverse nvarchar(260)
select @filename_reverse=reverse(@filename)
select @file_path=substring(@filename,1,len(@filename)+1-charindex('',@filename_reverse))
return @file_path
end


GO


/**//*恢复数据库*/
CREATE proc pr_restore_db
/**//*
------------------------------------------------
Create Time: 2004-03-20
Update Time: 2004-03-29 11:05
Author: aierong
Remark: 恢复数据库

------------------------------------------------
*/
/**//*过程运行的状态标志,是输入参数*/
@flag varchar(20) out,
/**//*要恢复的数据名字*/
@restore_db_name nvarchar(128),
/**//*备份文件存放的路径+备份文件名字*/
@filename nvarchar(260)
as
/**//*返回系统存储过程xp_cmdshell运行结果*/
declare @proc_result tinyint
/**//*循环次数*/
declare @loop_time smallint
/**//*@tem表的ids列最大数*/
declare @max_ids smallint
/**//*原数据库存放路径*/
declare @file_bak_path nvarchar(260)
/**//*文件存放标志*/
declare @flag_file bit
/**//*数据库master文件路径*/
declare @master_path nvarchar(260)
declare @sql nvarchar(4000),@par nvarchar(1000)
declare @sql_sub nvarchar(4000)
declare @sql_cmd nvarchar(100)
declare @sql_kill nvarchar(100)
/**//*
判断参数@filename文件格式合法性,以防止用户输入类似d: 或者 c:a 等非法文件名
参数@filename里面必须有''并且不以''结尾
*/
if right(@filename,1)<>'' and charindex('',@filename)<>0
begin
select @sql_cmd='dir '+@filename
EXEC @proc_result = master..xp_cmdshell @sql_cmd,no_output
/**//*系统存储过程xp_cmdshell返回代码值:0(成功)或1(失败)*/
IF (@proc_result<>0)
begin
/**//*备份文件不存在*/
select @flag='not exist'
/**//*退出过程*/
return
end
/**//*创建临时表,保存由备份集内包含的数据库和日志文件列表组成的结果集*/
create table #tem(
/**//*文件的逻辑名称*/
LogicalName nvarchar(128),
/**//*文件的物理名称或操作系统名称*/
PhysicalName nvarchar(260) ,
/**//*数据文件 (D) 或日志文件 (L)*/
Type char(1),
/**//*包含文件的文件组名称*/
FileGroupName nvarchar(128),
/**//*当前大小(以字节为单位)*/
[Size] numeric(20,0),
/**//*允许的最大大小(以字节为单位)*/
[MaxSize] numeric(20,0)
)
/**//*
创建表变量,表结构与临时表基本一样
就是多了两列,
列ids(自增编号列),
列file_path,存放文件的路径
*/
declare @tem table(
/**//*自增编号列*/
ids smallint identity,
LogicalName nvarchar(128),
PhysicalName nvarchar(260),
File_path nvarchar(260),
Type char(1),
FileGroupName nvarchar(128)
)
insert into #tem
execute('restore filelistonly from disk='''+@filename+'''')
/**//*将临时表导入表变量中,并且计算出相应得路径*/ http://www.knowsky.com/
insert into @tem(LogicalName,PhysicalName,File_path,Type,FileGroupName)
select LogicalName,PhysicalName,dbo.fn_GetFilePath(PhysicalName),Type,FileGroupName
from #tem
if @@rowcount>0
begin
drop table #tem
end
select @loop_time=1
/**//*@tem表的ids列最大数*/
select @max_ids=max(ids)
from @tem
while @loop_time<=@max_ids
begin
select @file_bak_path=file_path
from @tem where ids=@loop_time
select @sql_cmd='dir '+@file_bak_path
EXEC @proc_result = master..xp_cmdshell @sql_cmd,no_output
/**//*系统存储过程xp_cmdshell返回代码值:0(成功)或1(失败)*/
IF (@proc_result<>0)
select @loop_time=@loop_time+1
else
/**//*没有找到备份前数据文件原有存放路径,退出循环*/
BREAK
end
select @master_path=''
if @loop_time>@max_ids
/**//*备份前数据文件原有存放路径存在*/
select @flag_file=1
else
begin
/**//*备份前数据文件原有存放路径不存在*/
select @flag_file=0
select @master_path=dbo.fn_GetFilePath(filename)
from master..sysdatabases
where name='master'
end
select @sql_sub=''
/**//*type='d'是数据文件,type='l'是日志文件 */
/**//*@flag_file=1时新的数据库文件还是存放在原来路径,否则存放路径和master数据库路径一样*/
select @sql_sub=@sql_sub+'move '''+LogicalName+''' to '''
+case type
when 'd' then case @flag_file
when 1 then File_path
else @master_path
end
when 'l' then case @flag_file
when 1 then File_path
else @master_path
end
end
+case type
when 'd' then @restore_db_name
+'_DATA'
/**//*给文件编号*/
+convert(sysname,ids)
+'.'
/**//*给文件加入后缀名,mdf or ndf*/
+right(PhysicalName,3)
+''','
when 'l' then @restore_db_name
+'_LOG'
/**//*给文件编号*/
+convert(sysname,ids)
+'.'
/**//*给文件加入后缀名,mdf or ndf*/
+right(PhysicalName,3)
+''','
end
from @tem
select @sql='RESTORE DATABASE @db_name '
+'FROM DISK=@filename with '
select @sql=@sql+@sql_sub+'replace'
select @par='@db_name nvarchar(128),@filename nvarchar(260)'
/**//*关闭相关进程,把相应进程状况导入临时表中*/
select identity(int,1,1) ids, spid
into #temp
from master..sysprocesses
where dbid=db_id(@restore_db_name)
/**//*找到相应进程*/
if @@rowcount>0
begin
select @max_ids=max(ids)
from #temp
select @loop_time=1
while @loop_time<=@max_ids
begin
select @sql_kill='kill '+convert(nvarchar(20),spid)
from #temp
where ids=@loop_time
execute sp_executesql @sql_kill
select @loop_time=@loop_time+1
end
end
drop table #temp
execute sp_executesql @sql,
@par,
@db_name=@restore_db_name,
@filename=@filename
/**//*操作成功*/
select @flag='ok'
end
else
begin
/**//*参数@filename输入格式错误*/
SELECT @flag='file type error'
end


GO


/*运行*/

--备份数据库test_database
declare @fl varchar(10)
execute pr_backup_db @fl out,'test_database','c:/test_database.bak'
select @fl

--恢复数据库,输入的参数错误
declare @fl varchar(20)
exec pr_restore_db @fl out,'sa','c:/'
select @fl


--恢复数据库,即创建数据库test_database的复本test_db
declare @fl varchar(20)
exec pr_restore_db @fl out,'test_db','c:/test_database.bak'
select @fl

分享到:
评论

相关推荐

    MS SQL数据库备份和恢复存储过程

    MS SQL数据库备份和恢复存储过程 MS SQL数据库备份和恢复存储过程

    自动SQL数据库备份

    文件、数据、账务的备份是多么重要啊!实时备份、多路径、多硬盘实时备份 直接对MS SQL进行直接备份,备份文件压缩后存储。压缩率75%以上

    cpdb:Oscript应用程序可复制1C MS SQL数据库并部署到目标系统

    -创建MS SQL数据库的备份副本 恢复 -从备份还原MS SQL数据库 压缩 -压缩MS SQL数据库中的表和索引页 创维 -在1C服务器上创建信息库 杜比 -将信息库上传到文件 Restoreib -从文件加载信息库 Putyadisk -将文件放在...

    MSSQL数据库查看器

    功能简介: 、数据库基本对象的查看(库、表、主键、过程、函数、触发器、游标、视图等) ...、存储过程脚本 、过程参数列表 、数据库基本操作(分离、附加、备份、还原) 、对象相关性(未完成,因为懒) 、关键字加色显示

    SQL Server数据库在线管理系统

    连接你的SQL数据库,进行 1.建立,删除,修改数据表 2.建立,删除,修改每个表的字段操作 3.SQL语句执行容器,可以执行所有的SQL语句,包括存储过程,也可以检索、插入、更新、删除记录等操作 4.进行数据库的备份 目前该...

    MS SQL入门-进阶-实战培训.pdf

     3 设计实现数据库灾难备份和恢复   3.1 数据库备份   3.1.1 规划数据库备份策略   3.1.2 数据库完整备份   3.1.3 数据库差异备份   3.1.4 数据库日志备份   3.1.5 压缩备份   3.1.6 使用高级备份...

    MS-SQL-Server.rar_sql server

    MS SQL Server数据库生成Data备份的存储过程

    数据库开发助手DBDevTools

    MS SQLSERVER数据库管理提供:一、SQL备份恢复(包括本地备份和远程备份)。 二、SQL与第三方数据格式(EXCEL,ACCESS,DBF,TXT,远程MS SQLSERVER)导入导出 三、SQL语句查询、查询结果报表打印、执行语句提交 四...

    MSSQL_SERVER数据库增量同步软件(数据库结构及数据)

    首先把需要增量同步的数据库备份还原到另外一台电脑.这样二台的数据库是一模一样的了, 我的博客,我到时会发表一个纯SQL后台代码的增量同步代码. http://blog.csdn.net/jaimejth 使用方法: 1.配置源服务器和目的...

    北风数据库(Northwind)

    适用于MS SQL Server 2005和2008的范例数据库备份。不少翻译类书籍常用的范例库。这个版本包括了数据表、视图和相关的存储过程。

    Log Explorer for SQL Server v4.22 含注册机

    支持 MS SQL 2005 之前的版本 不支持 sql 2008 介绍 Log Explorer主要用于对MSSQLServer的事物分析和数据恢复。你可以浏览日志、导出数据、恢复被修改或者删除的数据(包括执行过update,delete,drop和truncate语句的...

    2009 年度十大 SQL Server 技巧文章

    不管你信不信,理解“黑盒”知识几乎可以在Microsoft SQL Server的所有方面起到帮助作用,例如从备份与存储到复制与镜像。  SQL Server运作的简短课程 实现SQL Server 2008中的文件流功能 SQL Server 2008中最新...

    Microsoft SQL Server 2005 Express Edition SP3

    有关如何备份、恢复和编辑注册表的信息,请参阅 Microsoft 知识库文章 256986。 若要手动增加计数器注册表项,请执行下列操作: 在任务栏中,依次单击“开始”和“运行”,在“运行”文本框中键入 regedit.exe,...

    ubarec:使用S3存储库进行通用备份和恢复

    该实用程序旨在将数据库备份和还原到S3存储。 到目前为止,支持PostgreSQL和MS SQL数据库。 安装 的Ubuntu 基本的依赖关系和软件包易于安装: sudo apt install -y p7zip-full unixodbc-dev python3.8 python3-pip...

    数据库管理系统(1).doc

    它使用户能方便地定义和操纵数据,维护数据的安全性和完整性,以及进行多用 户下的并发控制和恢复数据库。 按功能划分,数据库管理系统大致可分为6个部分: (1)模式翻译:提供数据定义语言(ddl)。用它书写的数据库...

    mssqldump:用于为 MS SQL 创建 dbdump 的 Powershell 实用程序,类似于 mysqldump 和 pg_dump

    #MS SQL Dump 这是一个简单的 PowerShell 脚本,可让您为 MS SQL 创建数据库导出,类似于使用mysqldump和pg_dump ##Usage 将$database更改$database您的数据库名称并从 PowerShell 运行脚本。 它将在当前目录中创建...

    数据库设计系列之一.pdf

    (6)数据库的维护:为数据库管理员提供软件⽀持,包括数据安全控制、完整性保障、数据库备份、以及性能监控等维护⼯具。 基于关系模型的数据库管理系统已⽇益完善,并作为商品化软件⼴泛应⽤于各⾏各业,它在各...

    基于JSP+SQL的城乡信息管理系统源码

    操作系统windos系统、数据库管理系统:SQL数据库系统。 3、接口 本产品的用户一般需要通过终端进行操作,进入主界面后点击相应的窗口,分别进入相对应的界面(如:输入界面、输出界面)。用户对程序的维护,最好要有...

Global site tag (gtag.js) - Google Analytics