一次性备份SQL Server中所有的数据

   本文原始来自网上一篇文章,不过原始的存储过程有些问题,本文经过验证并进行了进一步的修正,增加了备份的时候自动增加备份日期,文章内容如下:

  备份处理的存储过程

  set ANSI_NULLS ON

  set QUOTED_IDENTIFIER ON

  go

  /*--备份所有数据库

  备份的文件名为数据库名+日期+.bak

  将所有的用户数据库(或指定的数据库列表)

  备分到指定的目录下.

  /*--调用示例

  --备份所有用户数据库

  exec p_backupdb @bkpath='D:',@dbname=''

  --备份指定数据库

  exec p_backupdb @bkpath=D:',@dbname='数据库名称'

  --*/

  create proc [dbo].[p_backupdb]

  @bkpath nvarchar(260)='D:', --备份文件的存放目录,不指定则使用SQL默认的备份目录

  @dbname nvarchar(4000)='' --要备份的数据库名称列表,不指定则备份所有用户数据库

  as

  declare @sql varchar(8000)

  DECLARE @strdate NVARCHAR(200)

  set @strdate = convert(NVARCHAR(10),getdate(),120)

  set @strdate = REPLACE(@strdate, '-' , '')

  --检查参数

  if isnull(@bkpath,'')=''

  begin

  select @bkpath=rtrim(reverse(filename)) from master..sysfiles where name='master'

  select @bkpath=substring(@bkpath,charindex('',@bkpath)+1,4000)

  ,@bkpath=reverse(substring(@bkpath,charindex('',@bkpath),4000))+'BACKUP'

  end

  else if right(@bkpath,1)<>'' set @bkpath=@bkpath+''

  --得到要备份的数据库列表

  if isnull(@dbname,'')=''

  declare tb cursor local for

  select name from master..sysdatabases where name not in('master','tempdb','model','msdb')

  else

  declare tb cursor local for

  select name from master..sysdatabases

  where name not in('master','tempdb','model','msdb') and(name like '%'+@dbname+'%')

  --备份处理

  open tb

  fetch next from tb into @dbname

  while @@fetch_status=0

  begin

  set @sql='backup database '+@dbname

  +' to disk='''+@bkpath+@dbname +'_'+@strdate

  +'.bak'' with format'

  exec(@sql)

  fetch next from tb into @dbname

  end

  close tb

  deallocate tb

  go

时间: 2024-08-06 23:13:13

一次性备份SQL Server中所有的数据的相关文章

Sql Server中清空所有数据表中的记录_MsSql

Sql Server中清空所有数据表中的记录 清空所有数据表中的记录: 复制代码 代码如下: exec sp_msforeachtable  @Command1 ='truncate table ?' 删除所有数据表: 复制代码 代码如下: exec sp_msforeachtable 'delete   N''?''' 清空SQL Server数据库中所有表数据的方法(有约束的情况) 其实删除数据库中数据的方法并不复杂,为什么我还要多此一举呢,一是我这里介绍的是删除数据库的所有数据,因为数据之

用VB存取SQL Server中的图像数据

本文介绍MIS SQL Server对图像数据的存储机制和存取方法.针对VB开发工具,介绍了一种通过ADO Field 对象的GetChunk 方法和AppendChunk 方法来存取MIS SQL Server中的图像数据的方法. 在一个完善的医院信息MIS中,图像数据的存取是必不可少的,比如X光片.CT像片的保存.一方面,这些图像数据在远程诊疗为准确诊断病情提供了重要的依据,另一方面,也为快速查阅病人资料提供了基本条件.图像数据的存取在其它应用系统如GIS中也有广泛的应用. 1.SQL Se

[Python]Python/PHP如何查询sql server中NTEXT类型数据

[Python]Python/PHP如何查询sql server中NTEXT类型数据 Version Date Creator Description 1.0.0.1 2006-11-23 郑昀 草稿   继续阅读之前,我们假设您熟悉以下知识: n         Python / PHP n         SQL Server 2000 SP4以上版本的Microsoft sql server n         pymssql n         NTEXT类型 本文讨论了在Python中

.SQL Server中 image类型数据的比较

原文:.SQL Server中 image类型数据的比较 在SQL Server中如果你对text.ntext或者image数据类型的数据进行比较.将会提示:不能比较或排序 text.ntext 和 image 数据类型,除非使用 IS NULL 或 LIKE 运算符.不过image也是不支持like比较的.那怎么样对数据库中的图片做比较呢.对于这种大型对象的处理,在Oracle中有有专门的函数DBMS_LOB.COMPARE,而SQLSERVER中没有专门的处理函数,只能通过使用substri

删除sql server中重复的数据

原文:删除sql server中重复的数据 with list_numbers as( select Name, AuthorOrTime, Url, Price, EstimatePrice, Size, Category, ROW_NUMBER() over (order by Name, AuthorOrTime, Url, Price, EstimatePrice, Size, Category) as 'rownumber' from Arts)delete list_numbers

SQL Server中的XML数据进行insert、update、delete_mssql2005

SQL Server中新增加了XML.Modify()方法,分别为xml.modify(insert),xml.modify(delete),xml.modify(replace)对应XML的插入,删除和修改操作. 本文以下面XML为例,对三种DML进行说明: declare @XMLVar xml = ' <catalog> <book category="ITPro"> <title>Windows Step By Step</title&

SQL Server中sp_spaceused统计数据使用的空间总量不正确的原因

  很多时候,我们经常使用sp_spaceused来查看表的空间使用情况,上个月群里有个网友说他使用DELETE删除了数据后,使用sp_spaceused查看,发现该表的分配的空间总量(reserved)与数据使用的空间总量(data)没有变化,当时和他讨论了并分析了一下原因,随手记录了一下这个案例,这个周末刚好有点时间,正好分析整理一下这个案例.分享在这篇文章.如下所示,我们先构造数据,我们的测试案例比较极端,刚刚保证每个页面(page)刚好存储两条记录.如下所示:     USE Test

SQL Server中删除重复数据的方法

数据库的使用过程中由于程序方面的问题有时候会碰到重复数据,重复数据导致了数据库部分设置不能正确设置-- 方法一declare @max integer,@id integerdeclare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字段 having count(*) > 1open cur_rowsfetch cur_rows into @id,@maxwhile @@fetch_status=0begins

SQL Server中删除重复数据的几个方法

  数据库的使用过程中由于程序方面的问题有时候会碰到重复数据,重复数据导致了数据库部分设置不能正确设置-- 方法一 declare @max integer,@id integer declare cur_rows cursor local for select 主字段,count(*) from 表名 group by 主字段 having count(*) > 1 open cur_rows fetch cur_rows into @id,@max while @@fetch_status=