我的编程空间,编程开发者的网络收藏夹
学习永远不晚

sql server删除过期备份文件的脚本

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

sql server删除过期备份文件的脚本

一、通过脚本查看过期文件,时间可以自己设定

for /f "delims=" %i in ('dir /b /a-d "E:\mybak_file\*.bak" ^| findstr /i "backup" ^| findstr /v /i "no_backup"') do @if "%~ti" LSS "2024/09/29 16:50" echo %~ti NAME:%i

循环遍历查看小于指定时间点的文件 %i 是文件,也可以输出,切记 %~ti 的格式是 年/月/日 时:分
如果要对比的话要吧%~ti用双引号引起来,后面的时间字符串也引用起来!

二、删除过期文件

DECLARE @Path NVARCHAR(255) = 'E:\mybak_file\';  -- 备份文件存储路径
DECLARE @CutoffDate NVARCHAR(120) = REPLACE(CONVERT(VARCHAR(16), DATEADD(DAY, -14, GETDATE()), 120), '-', '/');
DECLARE @Cmd NVARCHAR(4000);

-- 删除超过两周的备份文件
SET @Cmd = 'for /f "delims=" %i in (''dir /b /a-d "' + @Path + '*.bak" | findstr /i "backup" | findstr /v /i "no_backup" '') do @if "%~ti" LSS "' + CONVERT(VARCHAR, @CutoffDate, 120) + '" del "' + @Path + '%i"';

-- 临时启用 xp_cmdshell
EXEC sp_configure 'show advanced options', 1;  
RECONFIGURE;  
EXEC sp_configure 'xp_cmdshell', 1;  
RECONFIGURE;

-- 执行您的命令
EXEC xp_cmdshell @Cmd;

-- 恢复 xp_cmdshell 的状态(可选)
EXEC sp_configure 'xp_cmdshell', 0;  
RECONFIGURE;

这里执行之后还是没有成功删除,继续修改脚本!!!!!!

三、问题解决

命令里面的管道符,必须要转义,否则会报错,报错内容如下

此时不应有 |。

管道符号(|)的误用: SQL Server 的 T-SQL 语言本身并不支持管道符号(|)。如果您尝试在 SQL 查询中直接使用它,可能会导致该错误。管道符号通常用于命令行界面或其他编程环境(例如 PowerShell)。

错误的命令: 如果您在 SQL Server 中执行的命令尝试以不正确的格式使用 SQL Server 的功能或选项,可能也会引发此错误。

真是一波三折啊,命令拼好如下:

for /f "delims=" %i in ('dir /b /a-d "E:\yunbak_file\*.bak" ^| findstr /i "backup" ^| findstr /v /i "no_backup" ') do @if "%~ti" LSS "2024/09/16 17:31" echo del "E:\yunbak_file\%i"

直接在cmd执行一点问题没有,但是用xp_cmdshell 执行,就是不行,还会误删所有文件,一直百思不得其解,后来多种测试以后发现是%~ti压根没有获取到。

终于找到方法解决了,真是太不容易了,不过还是对命令不熟悉,这里尝试多次后发现以下命令可以完美解决!!

for /f "tokens=1,2,4 delims= " %i in ('dir /T:W "E:\yunbak_file\*.bak" ^| findstr /i "backup" ^| findstr /v /i "no_backup" ') do @if "%i %j" LSS "2024/09/16 17:54" echo del "E:\yunbak_file\%k"

四、终极版本

以下是修改后的完整的清理备份文件的脚本(终极版本):

DECLARE @Path NVARCHAR(255) = 'E:\yunbak_file\';  -- 备份文件存储路径
DECLARE @CutoffDate NVARCHAR(120) = REPLACE(CONVERT(VARCHAR(16), DATEADD(DAY, -14, GETDATE()), 120), '-', '/');
DECLARE @Cmd NVARCHAR(4000);

-- 删除超过两周的备份文件

SET @Cmd = 'for /f "tokens=1,2,4 delims= " %i in (''dir /T:W "' + @Path + '*.bak" ^| findstr /i "backup" ^| findstr /v /i "no_backup" '') do @if "%i %j" LSS "' + CONVERT(VARCHAR, @CutoffDate, 120) + '" del "' + @Path + '%k"';

SELECT @Cmd;
-- 临时启用 xp_cmdshell
EXEC sp_configure 'show advanced options', 1;  
RECONFIGURE;  
EXEC sp_configure 'xp_cmdshell', 1;  
RECONFIGURE;


-- 执行您的命令
EXEC xp_cmdshell @Cmd;

-- 恢复 xp_cmdshell 的状态(可选)
EXEC sp_configure 'xp_cmdshell', 0;  
RECONFIGURE;

到此这篇关于sql server删除过期备份文件的脚本的文章就介绍到这了,更多相关sql server删除过期文件内容请搜索编程网(www.lsjlt.com)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网(www.lsjlt.com)!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

sql server删除过期备份文件的脚本

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

sql server删除过期备份文件的脚本

目录一、通过脚本查看过期文件,时间可以自己设定二、删除过期文件三、问题解决四、终极版本一、通过脚本查看过期文件,时间可以自己设定for /f "delims=" %i in ('dir /b /a-d "E:\mybak_file\*.b
sql server删除过期备份文件的脚本
2024-10-15

Shell脚本自动删除指定大小以上的备份文件

最近本地虚拟机的空间老是被备份给占满,为了偷懒不想自己天天登录上去清除,才写了这个自动清理脚本. 系统:centos 5.x 脚本内容: cat make_room.sh#!/bin/bash#size=`df -hP|grep /dev/
2022-06-04

shell备份文件、重命名文件、删除指定文件的脚本编写教程

本篇内容介绍了“shell备份文件、重命名文件、删除指定文件的脚本编写教程”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1,备份目录下面文件
2023-06-09

shell备份文件、重命名文件、删除指定文件的3个脚本分享

因为经常会用到shell脚本,所以经常会写一些,但是我从来没有系统的学习过shell脚本,遇到问题,就去看手册,或者google一下,到了一定的程度才发现自己的基础真的好差。下面在系统学习shell时,顺便写了点有用的小脚本。 1,备份目录
2022-06-04

Centos7下crontab+shell脚本定期自动删除文件

问题描述:最近有个需求,就是rsync每次同步的数据量很多,但是需要保留的数据库bak文件保留7天就够了,所以需要自动清理文件夹内的bak文件 解决方案:利用shell脚本来定期删除文件夹内的任务1、创建shell文件[root@zabbi
2022-06-03

自动备份MySQL到FTP并定期清理过期备份的Shell脚本分享

这篇文章主要介绍“自动备份MySQL到FTP并定期清理过期备份的Shell脚本分享”,在日常操作中,相信很多人在自动备份MySQL到FTP并定期清理过期备份的Shell脚本分享问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希
2023-06-09

怎么用Shell脚本自动删除指定大小以上的备份文件

这篇文章主要介绍“怎么用Shell脚本自动删除指定大小以上的备份文件”,在日常操作中,相信很多人在怎么用Shell脚本自动删除指定大小以上的备份文件问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么用Shel
2023-06-09

怎么用shell脚本实现对OGG进程过期trail文件的删除处理

本篇内容主要讲解“怎么用shell脚本实现对OGG进程过期trail文件的删除处理”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用shell脚本实现对OGG进程过期trail文件的删除处理”
2023-06-04

python 简单备份文件脚本v1.0的实例

整体思路 将要备份的目录列为一个列表,通过执行系统命令,进行压缩、备份。 这样关键在于构造命令并使用 os.system( )来执行,一开始使用zip 命令始终没有成功,后来发现Windows下并没有这个命令,还要安装GnuWin32项目,
2022-06-04

云服务器数据备份到本地文件怎么删除

如果您要删除云服务器的数据备份,可以按照以下步骤进行操作:登录您的云服务器服务提供商的数据备份中心,找到“备份到本地”选项,单击它。在本地,您可以选择备份到其他地方或者在本地存储备份文件。选择“备份到云”选项可以将数据备份到其他云平台中。单击“开始备份”按钮,开始对云服务器数据进行备份。备份过程可能需要较长的时间,请耐心等待,如有任何问题或需要帮助,请随时联系相关工作人员。备份完成后,您可以将备份文件保存到...
2023-10-27

解决Centos7下crontab+shell脚本定期自动删除文件问题

问题描述: 最近有个需求,就是rsync每次同步的数据量很多,但是需要保留的数据库bak文件 保留7天就够了,所以需要自动清理文件夹内的bak文件 解决方案: 利用shell脚本来定期删除文件夹内的任务 1、创建shell文件[ro
2022-06-04

腾讯云服务器备份到本地文件怎么删除

备份数据到本地首先,备份数据到本地是一项重要的任务。这意味着我们需要确保备份数据的安全,以防止数据丢失或被黑客攻击。备份数据到本地的方法包括:使用云存储服务备份数据到本地:在使用云存储服务时,您可以选择备份到云上的文件夹或云服务器上的数据库中。备份到本地的数据将保存在云服务器上,并且可以随时访问和恢复。使用本地存储备份
腾讯云服务器备份到本地文件怎么删除
2023-10-27

编程热搜

目录