一段脚本实现自动备份并保存最近几天的SQL数据库

日期:2020-04-29编辑作者:数据库

复制代码 代码如下: DECLARE @filename VARCHAR(255) DECLARE @date DATETIME SELECT @date=GETDATE() SELECT @filename = 'G:存放位置数据库名称-'+CAST(DATEPART(yyyy,@date) as varchar)+'-'+CAST(DATEPART(mm,@date) as varchar)+'-'+CAST(DATEPART(dd,@date) as varchar)+'.bak' BACKUP DATABASE [数据库名称] TO DISK = @filename WITH INIT GO DECLARE @OLDDATE DATETIME SELECT @OLDDATE=GETDATE()-5 EXECUTE master.dbo.xp_delete_file 0,N'G:存放位置',N'bak',@olddate,1 上面是一个备份最近5天的数据库作业脚本。

1.用sqlserver的维护计划

3)备份的路径尽量别选磁盘根目录。

在这里我就不给截图演示了,这个比较简单,无非就是通过sqlserver自己的维护计划拖拽出2个一个‘备份数据库'任务和一个‘清除维护'任务。

SET @SQL = ''SELECT @SQL = @SQL + 'BACKUP DATABASE ['+NAME+'] TO DISK = '''+@PATH+''+REPLACE(name,'.','')+@DDATE+'.bak '''FROM master..sysdatabasesWHERE NAME NOT IN ('master','tempdb','model','msdb')EXEC (@SQL)4.用powershell调用sqlcmd来执行备份命令。

SET @PATH = 'E:BackUp'SET @DDATE = convert(char(8),getdate(),112)

然后创建powershell脚本,将下边语句粘贴进去并保存成xx.ps1,在通过Windows的任务调度定时执行备份就可以了。复制代码 代码如下:$dbname = 'test'write-host "------"$dbname& cmd /c "sqlcmd -U sa -P 123456 -S 127.0.0.1 -Q `www.129028.com金沙," pr_1 '$dbname'`" "

如果数据库没开启xp_cmdshell的功能需要用以下脚本开通此功能,开通以后记得关闭sp_configure。复制代码 代码如下: USE Master GO EXEC sp_configure 'show advanced options', 1; GO RECONFIGURE WITH OVERRIDE; GO EXEC sp_configure 'xp_cmdshell',1; GO RECONFIGURE WITH OVERRIDE; GO 下边是备份的脚本复制代码 代码如下: DECLARE @DBNAME VARCHAR(128)DECLARE@PATH VARCHAR(50)DECLARE@SQL NVARCHAR(MAX)DECLARE@DDATE VARCHAR(8)

2)选项验证备份集完整性和压缩备份尽量都选上。

本文由www.129028.com金沙发布于数据库,转载请注明出处:一段脚本实现自动备份并保存最近几天的SQL数据库

关键词:

SQL Server 2000的安全配置

SQLserver2000数据库应用非常广泛,一旦出现安全问题,造成的损失往往难以估量!应提前预防,防患于未然。这里,我...

详细>>

如何查看某个查询用了多少TempDB空间www.129028.com金沙

DECLARE @read BIGINT, @write BIGINT; SELECT @read = SUM(num_of_bytes_read), @write = SUM(num_of_bytes_written) FROM tempdb.sys.database_files AS DBFJOI...

详细>>

浅析SQL语句中GROUP BY的用法

GROUP BY 是分组查询, 一般 GROUP BY 是和 聚合函数配合使用,你可以想想 你用了GROUP BY 按 ITEM.ITEMNUM这个字段分组,那其他字...

详细>>

微软总是试图使它的软件安装尽可能地简单顺www.129028.com金沙

如果你没有特意记录安装日期,那么有没有办法从SQL Server里查询到呢?想想我们在安装的时候,肯定会有Windows认证登...

详细>>