SQLserver使用脚本备份数据库
作者:网络转载 发布时间:[ 2016/1/11 13:20:50 ] 推荐标签:数据库
在SQLserver使用脚本备份数据库的时候需要注意的问题是:
1.指向的文件名必须是有读写权限。
2.在使用批量数据库备份时候需要根据自己需求选择性备份。
-- =============================================
-- Author: <奔跑的金鱼>
-- Blog: <http://www.cnblogs.com/OliverQin/>
-- Create date: <2015/01/04>
-- Description: <备份指定数据库>
-- =============================================
DECLARE
@FileName VARCHAR(200),
@CurrentTime VARCHAR(50),
@DBName VARCHAR(100),
@SQL VARCHAR(1000)
BEGIN
SET @CurrentTime = CONVERT(CHAR(8),GETDATE(),112) + CAST(DATEPART(hh, GETDATE()) AS VARCHAR) + CAST(DATEPART(mi, GETDATE()) AS VARCHAR)
SET @DBName='test'---------你要备份的数据库名
SET @FileName = 'C:ackup' + @DBName + '_' + @CurrentTime
SET @SQL = 'BACKUP DATABASE ['+ @DBName +'] TO DISK = ''' + @FileName + '.bak' +
''' WITH NOINIT, NOUNLOAD, NAME = N''' + @DBName + '_backup'', NOSKIP, STATS = 10, NOFORMAT'
PRINT @SQL
EXEC(@SQL)
END
--*************************************************************************************************
-- =============================================
-- Author: <奔跑的金鱼>
-- Blog: <http://www.cnblogs.com/OliverQin/>
-- Create date: <2015/01/04>
-- Description: <批量备份数据库>
-- =============================================
----------------------------------------------------申明变量
DECLARE
@FileName VARCHAR(200),
@CurrentTime VARCHAR(50),
@DBName VARCHAR(100),
@SQL VARCHAR(1000)
---------------------------------------------------获取当前时间
SET @CurrentTime = CONVERT(CHAR(8),GETDATE(),112) + CAST(DATEPART(hh, GETDATE()) AS VARCHAR) + CAST(DATEPART(mi, GETDATE()) AS VARCHAR)
---------------------------------------------------申明游标
DECLARE CurDBName CURSOR FOR
SELECT NAME FROM Master..SysDatabases where dbid>4
---------------------------------------------------打开游标
OPEN CurDBName
-----------------------------------------------------移动游标指向到第一条数据,提取第一条数据存放在变量中
FETCH NEXT FROM CurDBName INTO @DBName
-----------------------------------------------------如果上一次操作成功则继续循环
WHILE @@FETCH_STATUS = 0
BEGIN
--Execute Backup
SET @FileName = 'C:ackup' + @DBName + '_' + @CurrentTime
SET @SQL = 'BACKUP DATABASE ['+ @DBName +'] TO DISK = ''' + @FileName + '.bak' +
''' WITH NOINIT, NOUNLOAD, NAME = N''' + @DBName + '_backup'', NOSKIP, STATS = 10, NOFORMAT'
EXEC(@SQL)
--print @SQL
-----------------------------------------------------继续提下一行数据
FETCH NEXT FROM CurDBName INTO @DBName
END
---------------------------------------------关闭游标
CLOSE CurDBName
---------------------------------------------删除游标
DEALLOCATE CurDBName
--*************************************************************************************************
DECLARE @SQL VARCHAR(MAX)
SELECT @SQL = COALESCE(@SQL,'') + '
BACKUP DATABASE '+ QUOTENAME(name,'[]')
+ ' TO DISK = ''C:ackup'+ name + '_' + CONVERT(CHAR(8),GETDATE(),112) + CAST(DATEPART(hh, GETDATE()) AS VARCHAR) + CAST(DATEPART(mi, GETDATE()) AS VARCHAR) + '.bak'
+ ''' WITH NOINIT, NOUNLOAD, NAME = N''' + name + '_backup'', NOSKIP, STATS = 10, NOFORMAT'
FROM sys.databases WHERE database_id >4 AND name like '%%' AND state =0
PRINT(@SQL)
EXECUTE(@SQL)
只有自己想通了,说明你是真会了
相关推荐
更新发布
功能测试和接口测试的区别
2023/3/23 14:23:39如何写好测试用例文档
2023/3/22 16:17:39常用的选择回归测试的方式有哪些?
2022/6/14 16:14:27测试流程中需要重点把关几个过程?
2021/10/18 15:37:44性能测试的七种方法
2021/9/17 15:19:29全链路压测优化思路
2021/9/14 15:42:25性能测试流程浅谈
2021/5/28 17:25:47常见的APP性能测试指标
2021/5/8 17:01:11