博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Automatic Sql Server Backup Utility Using sqlserveragent
阅读量:5956 次
发布时间:2019-06-19

本文共 9128 字,大约阅读时间需要 30 分钟。

By Joshy George

Introduction

It is a sample C# (VS2005) application for Automatic Backup Utility using sqlserveragent. I have used SQL-DMO dll. This article will show you how to create a automatic backup in .

This should work on any use VB.NET and installed SQL Server 2000 (any edition or Client Components for SQL Server 2000.

SQLDMO (Which installed always bt MS SQL Server 2000 or MS SQL Server Client Tools

To do:

1) First Enter Your Sql Server username and password on   corresponding Text Box2) Set  Start date & Backup Time3) After Finishing this then please check manually it will working or not4) Manual working procedure:     1) Run Sql sever enterprise Manager    2) Select management Option    3) Open Sql server agent    4) Open Jobs window    5) Check whether job item exist or not    6) Right click on newly created job item then, we will get one     7) Popup menu, then select start job    8) After finish the job then check folder "D:\backup" bkp  created or not
Important Functions

Add reference to SQL-DMO dll

You can do this by right clicking the project in Solution Explorer, then selecting 'Add Reference', COM components and the latest version of " SQLDMO Object Library".

Available Server

public void dIsplayServerList(ComboBox cboListName)        {            try            {                SQLDMO.Application oSQLServerDMOApp = new SQLDMO.Application();                Info.informationLayer info = new Info.informationLayer();                                SQLDMO.NameList oNameList;                oNameList = oSQLServerDMOApp.ListAvailableSQLServers();                for (int intIndex = 0; intIndex <= oNameList.Count - 1; intIndex++)                {                    if (oNameList.Item(intIndex as object) != null)                    {                        cboListName.Items.Add(oNameList.Item(intIndex).ToString());                    }                }                if (cboListName.Items.Count > 0) cboListName.SelectedIndex = 0;                else cboListName.Text = "(Local)";            }            catch             {                            }Available databasespublic void dIsplayDatabases(ComboBox cboDatabase,Info.informationLayer info)        {            try            {                SQLDMO._SQLServer SQLServer = new SQLDMO.SQLServerClass();                cboDatabase.Items.Clear();                SQLServer.Connect(info.strServerName,info.strLoginName,info.strPwd);                foreach (SQLDMO.Database db in SQLServer.Databases)                {                    if (db.Name != null)                        cboDatabase.Items.Add(db.Name);                }                cboDatabase.Sorted = true;                if (cboDatabase.Items.Count == 0)cboDatabase.Text = "";            }            catch (Exception err)            {                info.ErrorMessageDataLayer = err.Message;            }        }Create Job on Server Agent :public void CreateJob_Sql(Info.informationLayer info)        {            {                try                {                    SQLDMO._SQLServer SQLServer = new SQLDMO.SQLServerClass();                    SQLDMO.Job SQLJob = new SQLDMO.Job();                    SQLDMO.JobSchedule SQLSchedule = new SQLDMO.JobSchedule();                    SQLServer.Connect(info.strServerName, info.strLoginName, info.strPwd);                    switch (SQLServer.JobServer.Status)                    {                        case SQLDMO_SVCSTATUS_TYPE.SQLDMOSvc_Stopped:                            SQLServer.JobServer.Start();                            SQLServer.JobServer.AutoStart = true;                            break;                    }                    SQLJob.Name = info.strDatabaseName;                    SQLJob.Description = "Check and Backup" + info.strDatabaseName;                    SQLServer.JobServer.Jobs.Add(SQLJob);                    SQLJob.Category = " Maintenance";                    SQLDMO.JobStep aJobStep = new SQLDMO.JobStep();                    aJobStep.Name = "Step 2: Backup the Database";                    aJobStep.StepID = 1;                    aJobStep.DatabaseName = info.strDatabaseName;                    aJobStep.SubSystem = "TSQL";                    //------>>> If BackUp Folder is Not Found then create BackUp Folder.                                                         string   DirectoryName = "D:\BackUp";                     if (Directory.Exists(DirectoryName)==false)                     {                         System.IO.Directory.CreateDirectory(DirectoryName);                     }                    //------>>>                    string sExt;                    sExt="EXEC master.dbo.xp_sqlmaint '-S " + info.strServerName + " -U " + info.strLoginName + " -P " + info.strPwd + "  -D " + info.strDatabaseName + " -CkDB -CkAl -CkCat -BkUpMedia DISK -BkUpDB D:\Backup  -BkExt BAK -DelBkUps 2weeks -BkUpOnlyIfClean -Rpt D:\Backup\BackDB_Checks.txt'";                    aJobStep.Command = sExt;                    aJobStep.OnSuccessAction = SQLDMO_JOBSTEPACTION_TYPE.SQLDMOJobStepAction_QuitWithSuccess;                    aJobStep.OnFailAction = SQLDMO_JOBSTEPACTION_TYPE.SQLDMOJobStepAction_QuitWithFailure;                    SQLJob.JobSteps.Add(aJobStep);                    SQLJob.ApplyToTargetServer(info.strServerName);                    aJobStep.DoAlter();                    SQLJob.Refresh();                    aJobStep.Refresh();                }                catch (Exception Err)                {                    info.ErrorMessageDataLayer = Err.Message;                }            }        }
Create Job shedule on server Agent:
public void CreateShedule_Sql(Info.informationLayer info)        {            try            {                //it will take bkp every week 2 day                SQLDMO.Job SQLJob = new SQLDMO.Job();                SQLDMO._SQLServer SQLServer = new SQLDMO.SQLServerClass();                SQLDMO.JobSchedule SQLSchedule = new SQLDMO.JobSchedule();                SQLServer.Connect(info.strServerName, info.strLoginName, info.strPwd);                SQLJob = SQLServer.JobServer.Jobs.Item(info.strDatabaseName);                // create a new JobSchedule object                SQLSchedule.Name = "Weekly Backup";                SQLSchedule.Schedule.FrequencyType = SQLDMO.SQLDMO_FREQUENCY_TYPE.SQLDMOFreq_Weekly;                SQLSchedule.Schedule.FrequencyInterval = 2;                SQLSchedule.Schedule.FrequencyRecurrenceFactor = 2;                 // // start on Feb18, 2000 - at 12.55                SQLSchedule.Schedule.ActiveStartDate = info.intStartDate;                SQLSchedule.Schedule.ActiveStartTimeOfDay = info.intStartTime;                  this schedule has no end time or end date                SQLSchedule.Schedule.ActiveEndDate = 99991231;                SQLSchedule.Schedule.ActiveEndTimeOfDay = 235959;                  add the schedule to the Job                SQLJob.BeginAlter();                SQLJob.JobSchedules.Add(SQLSchedule);                SQLJob.DoAlter();                //SQLJob.JobSchedules.Refresh();                info.ErrorMessageDataLayer = "New Sql Job [Databasename= " + info.strDatabaseName + " ]Sucessfully Created.  ";            }            catch (Exception err)            {                info.ErrorMessageDataLayer = err.Message;            }        }Syntax (SQL Server 2000)xp_sqlmaint 'switch_string'[    [-S server_name[\instance_name]]    [-U login_ID [-P password]]    {        [ -D database_name | -PlanName name | -PlanID guid ]        [-Rpt text_file]        [-To operator_name]        [-HtmlRpt html_file [-DelHtmlRpt ] ]        [-RmUnusedSpace threshold_percent free_percent]        [-CkDB | -CkDBNoIdx]        [-CkAl | -CkAlNoIdx]        [-CkCat]        [-UpdOptiStats sample_percent]        [-RebldIdx free_space]        [-WriteHistory]        [            {-BkUpDB [backup_path] | -BkUpLog [backup_path] }            {-BkUpMedia                {DISK [    [-DelBkUps ]                             [-CrBkSubDir ] [ -UseDefDir ]                         ]                | TAPE                }            }            [-BkUpOnlyIfClean]            [-VrfyBackup]        ]    }]time_periodnumber[minutes | hours | days | weeks | months]Syntax (SQL Server 7.0)sqlmaint [-?] |[    [-S server]    [-U login_ID [-P password]]    {        [ -D database_name | -PlanName name | -PlanID guid ]        [-Rpt text_file [-DelTxtRpt ] ]        [-To operator_name]        [-HtmlRpt html_file [-DelHtmlRpt ] ]        [-RmUnusedSpace threshold_percent free_percent]        [-CkDB | -CkDBNoIdx]        [-CkAl | -CkAlNoIdx]        [-CkTxtAl]        [-CkCat]        [-UpdSts]        [-UpdOptiStats sample_percent]        [-RebldIdx free_space]        [-WriteHistory]        [            {-BkUpDB [backup_path] | -BkUpLog [backup_path] }            {-BkUpMedia                {DISK [    [-DelBkUps ]                             [-CrBkSubDir ] [ -UseDefDir ]                         ]                | TAPE                }            }            [-BkUpOnlyIfClean]            [-VrfyBackup]        ]    }]

Download

转载于:https://www.cnblogs.com/wujun/archive/2006/12/11/588954.html

你可能感兴趣的文章
深入Spring:自定义注解加载和使用
查看>>
计划的定义与要素
查看>>
LR报错Error -27780: [GENERAL_MSG_CAT_SSL_ERROR]connect to host "XXX.XXX.com" failed解决方法
查看>>
mysql 索引B-Tree类型对索引使用的生效和失效情况详解
查看>>
获取表信息(MSSQL)
查看>>
css3 transform 旋转div
查看>>
一个batch如何通过一个网络
查看>>
沉没成本
查看>>
redux简明学习
查看>>
速度挑战 - 2小时完成HTML5拼图小游戏
查看>>
Exynos4412 IIC总线驱动开发(一)—— IIC 基础概念及驱动架构分析
查看>>
二叉树学习(二)
查看>>
外卖小程序对接飞鹅小票打印的实现
查看>>
鹅厂内部干货|微信小游戏开发技术怎么应用?
查看>>
指数基金投资指南读书笔记
查看>>
Java实现归并排序(转)
查看>>
background
查看>>
iOS __weak学习碰到的疑问
查看>>
no accounts with itunes connect access
查看>>
Hyperledger 项目
查看>>