0

0

SQL Server下利用vbscript 实现数据库月备份自动清理并发邮件提

php中文网

php中文网

发布时间:2016-06-07 15:24:01

|

1862人浏览过

|

来源于php中文网

原创

sql server下利用vbscript 实现数据库月备份自动清理并发邮件提醒 ---Summary--- 这份文档其实主要是讲vbscript的文件处理和在vbscript 下如何发邮件。大至分为三个部分。 一.Sql Server 数据库备份 二.Sql Server 调用vbs对数据库备份文件夹进行扫描,清

sql server下利用vbscript 实现数据库月备份自动清理并发邮件提醒

---Summary---

这份文档其实主要是讲vbscript的文件处理和在vbscript 下如何发邮件。大至分为三个部分。

一.Sql Server 数据库备份

二.Sql Server 调用vbs对数据库备份文件夹进行扫描,清理以前旧的数据库备份,只保留当前月的数据库备份。

三.将清除的数据库备份文件以附件的形式通知数据库管理员。

---Detailes---

1. Sql Server 数据库备份,以Job 的方式来实现,数据库备份文件名以日期的格式命名。

SQL Server下利用vbscript 实现数据库月备份自动清理并发邮件提

SQL Server下利用vbscript 实现数据库月备份自动清理并发邮件提

 

Step Name: Bakup Training DB

Type: Transact-SQL Script(T-SQL)

Database: ASATTraining

 

Command:

declare @filename nvarchar(100)

set @filename='D:/TRSYS_DB_BAK/'+convert(char(10),getdate(),112)

print @filename

BACKUP DATABASE [ASATTraining] TO DISK = @filename WITH NOINIT , NOUNLOAD , NAME = N'ASATTraining', NOSKIP , STATS = 10, NOFORMAT

 

 

2. Sql Server 调用vbs实现清理上个月的备份文件,写清理日志,发邮件。

1).数据库文件和清理日志文件夹

SQL Server下利用vbscript 实现数据库月备份自动清理并发邮件提

 

2).清理数据库日志的程序文件夹,下面就分别讲讲这个文件夹内每个文件的具体用途。

 

SQL Server下利用vbscript 实现数据库月备份自动清理并发邮件提

 

 

i)Email 里有一个Email_List.txt 的文件,它是记录邮件接受者的用件地址。

每行显示一个邮件地址,具体如下:

Email_List.txt

lilo.zhu@gmail.com

lilo.zhu@ymail.com

lilo.zhu@qq.com

 

ii)Log 内是清除数据库备文件时记录的日志文件,文件以系统日期.log 形式命名。

 

 

SQL Server下利用vbscript 实现数据库月备份自动清理并发邮件提

 

 

iii) Backup_Clear.bat 文件是供Sql Server job 是调用的。

 

SQL Server下利用vbscript 实现数据库月备份自动清理并发邮件提

Step Name: Run Clear Last Month Backup Database Data

Type: Operation System (CmdExec)

Run as: SQL Agent Service Account

Command: D:/TRSYS_DB_BAK_CLEAR/Backup_Clear.bat

 

Backup_Clear.bat

 

d:

cd d:/TRSYS_DB_BAK_CLEAR

Backup_Clear.vbs D:/TRSYS_DB_BAK

 

iv) Backup_Clear.vbs 是实现在清除非本月数据库备份文件,写清除日志,发送邮件的具体脚本程序,内容如下:

 

Backup_Clear.vbs

 

'------------------------------------------------------------

'DataBase Backup Data Clear

'Auto Clear Last Month Database Backup Data 

'

'Create Date: 2009-09-29

'Author:   Wei_Zhu

'Chage Log:

'Last Chage Date:

'-------------------------------------------------------------

 

Const ForReading = 1, ForWriting = 2, ForAppending = 8

Const TristateUseDefault = -2, TristateTrue = -1, TristateFalse = 0

 

Dim ObjArgs

Set ObjArgs = Wscript.Arguments

 

set ws=createobject("wscript.shell")

If ObjArgs.Count > 0  then

'WSH.Echo "The Folder Name is: "& ObjArgs(0)

     ShowFolderList(ObjArgs(0))

else

     Wscript.Echo "Please Input The Full Folder Path..."

end if

 

Function ShowFolderList(ByVal lstg_folder_name)

    Dim fso, f, f1, fc, s, folder

    Dim l_count

    l_count = 1

    fso = CreateObject("Scripting.FileSystemObject")

    folder = fso.getfolder(ws.currentdirectory)

    f = fso.GetFolder(lstg_folder_name)

    fc = f.files

    For Each f1 In fc

        Dim ldt, lf

        ldt = int(mid(f1.name, 5, 2))

        'msgbox Month(Now) &" || " & Month(ldt)

        If Month(Now) > ldt Then

            If right(lstg_folder_name, 1) "/" Then

               lf=lstg_folder_name& "/" & f1.name

            End If

            DeleteFile(lf)

            l_count = l_count + 1

        End If

    Next

    If l_count > 0 Then

        l_email_address = folder & "/Email/Email_List.txt"

        SendEmail(l_email_address)

    End If

End Function

 

Function DeleteFile(ByVal lstg_file_name)

    Dim lstg_msg

    fso = CreateObject("Scripting.FileSystemObject")

    f = fso.GetFile(lstg_file_name)

    f.Delete()

    'msgbox(lstg_file_name & " delete file success !")

    lstg_msg = Now & " Last Month Database Backup File: " & lstg_file_name & " Delete Success !"

    WriteLog(lstg_msg)

End Function

 

Function WriteLog(ByVal lstg_log_msg)

    Dim fso, f, LogFile, l_file_name, folder, l_email_address

   dt=replace(date,"/","-")

    fso = CreateObject("Scripting.FileSystemObject")

    folder = fso.getfolder(ws.currentdirectory)

 

    '---Check Log Folder Exists---

    'If (Not fso.FolderExists(lstg_log_folder)) Then

    '    fso.CreateFolder(lstg_log_folder)

    'End If

 

    'if right(lstg_log_folder,1)"/" then

    '         lstg_log_folder=lstg_log_folder& "/"

    'end if

   l_file_name=folder& "/Log/" & dt & ".log"

 

    '---Check Log File Exists---

    If (fso.FileExists(l_file_name)) Then

        f = fso.GetFile(l_file_name)

        LogFile = f.OpenAsTextStream(ForAppending, TristateUseDefault)

        LogFile.WriteLine(lstg_log_msg)

        LogFile.Close()

    Else

        LogFile = fso.CreateTextFile(l_file_name, True)

        LogFile.WriteLine(lstg_log_msg)

        LogFile.Close()

    End If

End Function

 

Function SendEmail(ByVal lstg_email_list)

   dt=replace(date,"/","-")

    Dim fso, Email_File, folder, str_mail_address, Attached_File

    fso = CreateObject("Scripting.FileSystemObject")

    'msgbox lstg_email_list

    Email_File = fso.OpenTextFile(lstg_email_list, ForReading, False)

    Do While Email_File.AtEndOfStream True

        str_mail_address = str_mail_address & Email_File.ReadLine & ";"

    Loop

    Email_File.Close()

    'msgbox str_mail_address

 

    folder = fso.getfolder(ws.currentdirectory)

   if fso.FileExists(folder& "/Log/" & dt & ".log") then

      Attached_File=folder& "/Log/" & dt & ".log"

    End If

    'msgbox Attached_File

    '---Send Emial---

 

     NameSpace = "http://schemas.microsoft.com/cdo/configuration/"

     Set Email = CreateObject("CDO.Message")

     Email.From = "lilo.zhu@ymail.com"

     Email.To = str_mail_address

     Email.Subject = "DataBase Bakup Data Clear Message"

     Email.HTMLBody = "Hi DBA:
Clear Last Month Database Backup Data Complete,Please See Teh Attached File..."

        if Attached_File "" then

       Email.AddAttachment Attached_File

     end if

 

     With Email.Configuration.Fields

     .Item(NameSpace&"sendusing") = 2

     .Item(NameSpace&"smtpserver") = "smtp.mail.yahoo.com"

     .Item(NameSpace&"smtpserverport") = 25

     .Item(NameSpace&"smtpauthenticate") = 1

     .Item(NameSpace&"sendusername") = "lilo.zhu@ymail.com"

     .Item(NameSpace&"sendpassword") = "123456"

     .Update

     End With

     Email.Send

 

End Function

 

 

---Remark---

1.       vbs 中发邮件是使用CDO.Message 这个对象。

2.       Sql Server 调用带参数的bat 批处理容易出问题,最好将参数都写在bat 文件内,Sql Server 只需调用这个bat 批处理文件就行了。

相关专题

更多
php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

3

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

1

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

5

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

7

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

30

2025.12.31

html5怎么播放视频
html5怎么播放视频

想让网页流畅播放视频?本合集详解HTML5视频播放核心方法!涵盖<video>标签基础用法、多格式兼容(MP4/WebM/OGV)、自定义播放控件、响应式适配及常见浏览器兼容问题解决方案。无需插件,纯前端实现高清视频嵌入,助你快速打造现代化网页视频体验。

3

2025.12.31

关闭win10系统自动更新教程大全
关闭win10系统自动更新教程大全

本专题整合了关闭win10系统自动更新教程大全,阅读专题下面的文章了解更多详细内容。

2

2025.12.31

阻止电脑自动安装软件教程
阻止电脑自动安装软件教程

本专题整合了阻止电脑自动安装软件教程,阅读专题下面的文章了解更多详细教程。

3

2025.12.31

html5怎么使用
html5怎么使用

想快速上手HTML5开发?本合集为你整理最实用的HTML5使用指南!涵盖HTML5基础语法、主流框架(如Bootstrap、Vue、React)集成方法,以及无需安装、直接在线编辑运行的平台推荐(如CodePen、JSFiddle)。无论你是新手还是进阶开发者,都能轻松掌握HTML5网页制作、响应式布局与交互功能开发,零配置开启高效前端编程之旅!

2

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
SQL 教程
SQL 教程

共61课时 | 3.2万人学习

SQL优化与排查(MySQL版)
SQL优化与排查(MySQL版)

共26课时 | 2.2万人学习

MySQL索引优化解决方案
MySQL索引优化解决方案

共23课时 | 2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号