`
zzx0421
  • 浏览: 97240 次
  • 性别: Icon_minigender_1
  • 来自: 株洲/深圳
社区版块
存档分类
最新评论

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

阅读更多
if exists(
 select * from sysobjects
  where name='pr_backup_db' and xtype='p'
 )
begin
 drop proc pr_backup_db
end
go
/*备份数据库*/
create proc pr_backup_db
@flag varchar(10) out,
@backup_db_name varchar(128),
@filename varchar(1000)  --路径+文件名字
as
declare @sql nvarchar(4000),@par nvarchar(1000)
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'
go

 if exists(
 select * from sysobjects
  where name='fn_GetFilePath' and xtype='fn'
 )
begin
 drop function fn_GetFilePath
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

if exists(
 select * from sysobjects
  where name='pr_restore_db' and xtype='p'
 )
begin
 drop proc pr_restore_db
end
go
create proc pr_restore_db    /*恢复数据库*/
@flag varchar(20) out,    /*过程运行的状态标志,是输入参数*/      
@restore_db_name nvarchar(128),  /*要恢复的数据名字*/
@filename nvarchar(260)         /*备份文件存放的路径+备份文件名字*/
as
declare @proc_result tinyint  /*返回系统存储过程xp_cmdshell运行结果*/
declare @loop_time smallint  /*循环次数*/
declare @max_ids smallint    /*@tem表的ids列最大数*/
declare @file_bak_path nvarchar(260)  /*原数据库存放路径*/
declare @flag_file bit   /*文件存放标志*/
declare @master_path nvarchar(260)  /*数据库master文件路径*/
declare @sql nvarchar(4000),@par nvarchar(1000)
declare @sql_sub nvarchar(4000)
declare @sql_cmd nvarchar(4000) 
/*
判断参数@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
 IF (@proc_result<>0)  /*系统存储过程xp_cmdshell返回代码值:0(成功)或1(失败)*/
 begin
  select @flag='not exist'   /*备份文件不存在*/
  return  /*退出过程*/
 end
 /*创建临时表,保存由备份集内包含的数据库和日志文件列表组成的结果集*/
 create table #tem(
     LogicalName nvarchar(128), /*文件的逻辑名称*/
     PhysicalName nvarchar(260) , /*文件的物理名称或操作系统名称*/
     Type char(1),  /*数据文件 (D) 或日志文件 (L)*/
     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+'''')
 /*将临时表导入表变量中,并且计算出相应得路径*/
 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
 select @max_ids=max(ids)  /*@tem表的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+'_'+LogicalName+'_data.mdf'','  
    when 'l' then @restore_db_name+'_'+LogicalName+'_log.ldf'','  
    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)'
 print @sql
 execute sp_executesql @sql,@par,@db_name=@restore_db_name,@filename=@filename
 select @flag='ok'   /*操作成功*/
end
else
begin
 SELECT @flag='file type error'  /*参数@filename输入格式错误*/
end

--备份数据库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
分享到:
评论

相关推荐

    自动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 含注册机

    他可以支持SQLServer7.0、SQLServer2000和SQLServer2005,提取标准数据库的日志文件或者备份文件中的信息。 其中提供两个强大的工具:日志分析浏览,对象恢复。具体功能如下: l 日志文件浏览 l 数据库变更审查 l...

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

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

    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,...

    数据库管理系统(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