IT猫扑网:您身边最放心的安全下载站! 最新更新|软件分类|软件专题|手机版|论坛转贴|软件发布

您当前所在位置:首页数据库MSSQL → SQL Server通过代码执行代理任务

SQL Server通过代码执行代理任务

时间:2015/6/28来源:IT猫扑网作者:网管联盟我要评论(0)

今天被人问到,假如我们需要在代码中执行sql server 的代理任务,那么有什么思路呢?

我马上想到,一般会有两种思路

1. 通过SMO(SQL Server Management Object Model)

2. 通过存储过程

下面首先介绍的是通过SMO的手段

1. 首先要添加两个程序集的引用

image

2. 然后编写代码

using Microsoft.SqlServer.Management.Smo;
using Microsoft.SqlServer.Management.Smo.Agent;

 

///


/// 列出某个服务器上面所有的代理作业
/// 作者:陈希章
///
///
///
private void btList_Click(object sender, EventArgs e)
{
Server svr = new Server("Thinker");
foreach (Job item in svr.JobServer.Jobs)
{
lstJobs.Items.Add(item);
}
}
///
/// 双击运行某个作业
/// 作者:陈希章
///
///
///
private void lstJobs_MouseDoubleClick(object sender, MouseEventArgs e)
{
Job item = lstJobs.SelectedItem as Job;
item.Start();
}

image

 这是相当方便的。但有一个问题就是SMO这种操作必须在服务器由管理员身份执行。

那么,有没有办法在T-SQL中通过存储过程的方式调用呢?

1. 首先要知道的是,Job的信息是放在MSDB的,所以需要在MSDB里面想办法。而且也应该让调用方具有MSDB的一些权限

image

2. 我们很快就定位到了这个存储过程sp_start_job。下面是一个范例

USE msdb ;
GO

EXEC dbo.sp_start_job N'THINKER-demo-demo_products_merge-THINKER-1' ;
GO

相比较而言,用T-SQL的方式更加易于实现。

image

关键词标签:SQL Server,代理

相关阅读

文章评论
发表评论

热门文章 SqlServer2005对现有数据进行分区具体步骤SqlServer2005对现有数据进行分区具体步骤sql server系统表损坏的解决方法sql server系统表损坏的解决方法MS-SQL2005服务器登录名、角色、数据库用户MS-SQL2005服务器登录名、角色、数据库用户Access、SQL Server、Oracle常见应用的区别Access、SQL Server、Oracle常见应用的区别

相关下载

人气排行 如何远程备份(还原)SQL2000数据库SQL2000数据库远程导入(导出)数据配置和注册ODBC数据源-odbc数据源配置教程SQL2000和SQL2005数据库服务端口查看或修改SQL Server 2005降级到2000的正确操作步骤修改Sql Server唯一约束教程浅谈JSP JDBC来连接SQL Server 2005的方法SQL Server创建表语句介绍