创建作业(JOB)

在SQL Server日常需求处理中,会遇到定时执行或统计数据的需求,这时我们可以通过作业(JOB)来处理,从而通过代理的方式来实现数据的自动处理。一下为SQL Server中创建作业的脚本,供大家参考使用。

一、创建作业(JOB)

-- SQL SERVER2000 作业(JOB)T-SQL创建脚本
-- author: jiajia
-- 服务器: (local)

--参数说明:
-- daily_pr_stat_test (作业名称:测试JOB名称,可根据需求进行修改)
-- @command = N‘exec pr_stat_test‘ (作业调用可执行存储过程或SQL语句:pr_stat_test--执行数据统计的可运行存储过程,当然你也可以换成可执行的SQL语句)
-- @database_name = N‘test‘ (运行数据库:test--存储过程所在库)
-- @active_start_date = 20121207 (作业执行的开始日期:为NULL时表示当前日期,格式为YYYYMMDD。20121207--该作业开始执行日期)
-- @active_end_date = 99991231 (作业执行的停止日期:默认为99991231,格式为YYYYMMDD)
-- @active_start_time = 84100 (作业执行的开始时间:格式为HHMMSS,84100--该作业开始执行时间)
-- @active_end_time = 235959 (作业执行的停止时间:格式为HHMMSS,235959--该作业执行结束时间)
-- @freq_type = 4 (作业执行时间的值:1--一次;4--每天;8--每周;16--每月;32--每月,相对于 freqinterval;64--SQLServerAgent 服务启动时运行;128--计算机空闲时运行)
-- @freq_interval = 1 (重复执行次数:1--每天执行一次)
-- @freq_subday_type = 1 (重复方式:0x1--在指定的时间;0x2--秒;0x4--分钟;0x8--小时)
-- @freq_subday_interval = 0 (重复周期数:0--不重复,1--每小时执行一次)
-- @freq_relative_interval = 0 (第几个相对时间执行:允许的值为1,2,4,8代表第1~4个相对时间,16表示最后一个相对时间)
-- @freq_recurrence_factor = 0 (作业的两次计划执行之间的间隔周数或月数:只有 freq_type 为 8、16 或 32 时,才会使用 freq_recurrence_factor)

BEGIN TRANSACTION           
  DECLARE @JobID BINARY(16) 
  DECLARE @ReturnCode INT   
  SELECT @ReturnCode = 0

--判断本地作业类别是否存在,不存在则添加
IF (SELECT COUNT(*) FROM msdb.dbo.syscategories WHERE name = N‘[Uncategorized (Local)]‘) < 1
  EXECUTE msdb.dbo.sp_add_category @name = N‘[Uncategorized (Local)]‘

--判断作业是否存在,如存在则提示处理,不存在则新建
IF (SELECT COUNT(*) FROM msdb.dbo.sysjobs WHERE name = N‘daily_pr_stat_test‘) > 0
  PRINT N‘作业“daily_pr_stat_test”已经存在,因而将不被替换。‘
ELSE
BEGIN

-- 添加作业
  EXECUTE @ReturnCode = msdb.dbo.sp_add_job @job_id = @JobID OUTPUT , @job_name = N‘daily_pr_stat_test‘, @owner_login_name = N‘sa‘,

@description = N‘没有可用的描述。‘, @category_name = N‘[Uncategorized (Local)]‘, @enabled = 1, @notify_level_email = 0, @notify_level_page

= 0, @notify_level_netsend = 0, @notify_level_eventlog = 2, @delete_level= 0
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

-- 添加作业步骤
  EXECUTE @ReturnCode = msdb.dbo.sp_add_jobstep @job_id = @JobID, @step_id = 1, @step_name = N‘1‘, @command = N‘exec pr_stat_test‘,

@database_name = N‘test‘, @server = N‘‘, @database_user_name = N‘‘, @subsystem = N‘TSQL‘, @cmdexec_success_code = 0, @flags = 0,

@retry_attempts = 0, @retry_interval = 1, @output_file_name = N‘‘, @on_success_step_id = 0, @on_success_action = 1, @on_fail_step_id = 0,

@on_fail_action = 2
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
  EXECUTE @ReturnCode = msdb.dbo.sp_update_job @job_id = @JobID, @start_step_id = 1

IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

-- 添加作业调度
  EXECUTE @ReturnCode = msdb.dbo.sp_add_jobschedule @job_id = @JobID, @name = N‘1‘, @enabled = 1, @freq_type = 4, @active_start_date =

20121207, @active_start_time = 84100, @freq_interval = 1, @freq_subday_type = 1, @freq_subday_interval = 0, @freq_relative_interval = 0,

@freq_recurrence_factor = 0, @active_end_date = 99991231, @active_end_time = 235959
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

-- 添加目标服务器
  EXECUTE @ReturnCode = msdb.dbo.sp_add_jobserver @job_id = @JobID, @server_name = N‘(local)‘
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback

END
COMMIT TRANSACTION         
GOTO   EndSave             
QuitWithRollback:
  IF (@@TRANCOUNT > 0) ROLLBACK TRANSACTION
EndSave:

二、删除作业(JOB)

1、使用 SQL Server Management Studio删除

删除单个作业:

在“对象资源管理器”中,连接到 SQL Server 数据库引擎实例,再展开该实例。
   依次展开“SQL Server 代理”和“作业”,右键单击要删除的作业,再单击“删除”。
   在“删除对象”对话框中,确认选择了要删除的作业。
   单击“确定”。

删除多个作业:

在“对象资源管理器”中,连接到 SQL Server 数据库引擎实例,再展开该实例。
   展开“SQL Server 代理”。
   右键单击“作业活动监视器”,然后单击“查看作业活动”。
   在作业活动监视器中,选择要删除的作业,右键单击选择的作业,然后选择“删除作业”。

2、使用SQL语句删除

USE msdb ;
   GO

EXEC sp_delete_job

@job_name = N‘daily_pr_stat_test‘ ;
   GO

三、查看作业(JOB)的相关信息

-- 查看作业是否存在
SELECT COUNT(*) FROM msdb.dbo.sysjobs WHERE name = N‘daily_pr_stat_test‘

--查询作业运行状态信息(run_status: 0=出错失败,1=成功,3=已取消,5=状态未知),SQL Server2005以上
exec msdb.dbo.sp_help_jobactivity  @job_name=N‘daily_pr_stat_test‘

-- 查看数据库中当前定义的所有作业的全部属性
exec msdb..sp_help_job

--查看作业历史

select a.*,b.name

from msdb.dbo.sysjobhistory a

inner join msdb.dbo.sysjobs b

on a.job_id=b.job_id

and b.name=‘daily_pr_stat_test‘

--and a.run_status=0 --作业失败信息
order by a.run_time desc

-- 查看指定作业的全部属性
exec msdb..sp_help_job @job_name=N‘daily_pr_stat_test‘

-- 可查看执行语句或者存储过程等等
exec msdb..sp_help_jobstep @job_name=N‘daily_pr_stat_test‘

-- 查看作业历史执行时间等信息

A、SQL Server2000版本中:

SELECT  j.name AS ‘JobName‘, 
        s.step_id AS ‘Step‘, 
        s.step_name AS ‘StepName‘,
        run_date, 
        run_time, 
        convert(varchar(32),left(run_date,4)+‘-‘+substring(convert(varchar(10),run_date),5,2)+‘-‘+right(run_date,2),120)+‘ ‘
       +substring(convert(varchar(10),run_time),1,len(run_time)-4)+‘:‘+substring(convert(varchar(10),run_time),len(run_time)-3,2)+‘:‘+right(run_time,2) AS ‘RunDateTime‘,    
        ((run_duration /10000 * 3600 + (run_duration / 100 ) % 100 * 60 + run_duration % 100 + 31) / 60) AS ‘RunDurationMinutes‘ 
FROM    msdb.dbo.sysjobs j 
        INNER JOIN msdb.dbo.sysjobsteps s ON j.job_id = s.job_id 
        INNER JOIN msdb.dbo.sysjobhistory h ON s.job_id = h.job_id 
        AND s.step_id = h.step_id 
        AND h.step_id <> 0 
WHERE   j.enabled = 1  --Only Enabled Jobs 
and j.name like ‘%vip_report%‘
ORDER   BY JobName,RunDateTime DESC

B、SQL Server2005以上版本中:
SELECT  j.name AS ‘JobName‘ , 
        s.step_id AS ‘Step‘ , 
        s.step_name AS ‘StepName‘ , 
        msdb.dbo.agent_datetime(run_date, run_time) AS ‘RunDateTime‘ , 
        (( run_duration / 10000 * 3600 + (run_duration / 100) % 100 * 60 + run_duration % 100 + 31) / 60) AS ‘RunDurationMinutes‘ 
FROM    msdb.dbo.sysjobs j 
        INNER JOIN msdb.dbo.sysjobsteps s ON j.job_id = s.job_id 
        INNER JOIN msdb.dbo.sysjobhistory h ON s.job_id = h.job_id 
        AND s.step_id = h.step_id 
        AND h.step_id <> 0 
WHERE   j.enabled = 1   --Only Enabled Jobs 
ORDER  BY JobName,RunDateTime DESC

四、修改指定作业(JOB)相关属性值

1、修改作业开始执行日期和时间

update a

set a.active_start_date=‘20141010‘,a.active_start_time=‘082000‘

from msdb.dbo.sysschedules a,msdb.dbo.sysjobschedules b,msdb.dbo.sysjobs c

where a.schedule_id=b.schedule_id

and b.job_id=c.job_id

and c.name=N‘daily_pr_stat_test‘

2、修改指定作业下次执行时间

update a
set next_run_time=‘114000‘
from msdb.dbo.sysjobschedules a,msdb.dbo.sysjobs b
where a.job_id=b.job_id
and b.name=N‘daily_pr_stat_test‘

3、启用作业

exec msdb.dbo.sp_update_job @job_name=‘daily_pr_stat_test‘,@enabled=1

4、禁用作业

exec msdb.dbo.sp_update_job @job_name=‘daily_pr_stat_test‘,@enabled=0

5、立即运行作业
exec msdb.dbo.sp_start_job N‘daily_pr_per_test‘

6、立即停止正在运行中的作业(可能导致不可预知的结果)
exec msdb.dbo.sp_stop_job N‘daily_pr_per_test‘

7、修改作业其他参数

exec msdb..sp_update_job @job_name=N‘daily_pr_stat_test‘

更多相关参数请参考:http://technet.microsoft.com/zh-cn/magazine/ms188745(SQL.105).aspx

注:更多详细参数说明请参考:http://msdn.microsoft.com/zh-cn/library/ms182079(v=sql.105).aspx或者http://msdn.microsoft.com/zh-cn/library/ms187354(v=sql.105).aspx/css

时间: 2024-10-11 12:55:57

创建作业(JOB)的相关文章

sqlserver 使用脚本创建作业

use master go --定义创建作业 DECLARE @jobid uniqueidentifier, @jobname sysname SET @jobname = N'testInterval' IF EXISTS(SELECT * FROM msdb.dbo.sysjobs WHERE [email protected]) EXEC msdb.dbo.sp_delete_job @[email protected] EXEC msdb.dbo.sp_add_job @job_nam

sql创建作业实现循环执行操作

sqlserver创建作业: 1:写好需要执行的存储过程 2:新建作业: 3:设置作业信息: 4:配置好作业后,程序就自动每天执行了

T-SQL创建作业

/*1.--创建作业 */ /*--调用示例 --每月执行的作业 exec p_createjob @jobname='mm',@sql='select * from syscolumns',@freqtype='month' --每周执行的作业 exec p_createjob @jobname='ww',@sql='select * from syscolumns',@freqtype='week' --每日执行的作业 exec p_createjob @jobname='a',@sql='

创建作业的SQL

创建备份MYDB的备份脚本,并删除5天前备份 USE msdb ; GO EXEC dbo.sp_add_job     @job_name = 'Job_backup_DB',  --作业的名称     @enabled = 1, --指示添加的作业的状态(默认值为(启用))     @description = '数据库定期备份作业!', --作业的说明     @owner_login_name = 'sa', --拥有作业的登录名     @notify_level_eventlog =

SQL Server 创建作业

如果有一项工作需要自动执行,比如每个多长时间或者是每天几点的时候执行一次,那么可以使用SQL Server 的作业功能.使用步骤如下: 1.打开Sql Server配置管理器 2.发现SQL Server代理无法使用,首先要开启代理服务(若已经开启,请忽略) 3.计算机(右键)->管理->服务->SQL Server代理(MSSQLSERVER)->开启,刷新SQL Server配置管理器,发现SQL Server代理已经启用,可以使用作业. 4.在SQL Server配置管理器中

使用Activiti内部Api手动创建作业(Job)

很多时候,我们想像Activiti定时开始事件一样,加入一些自己的定时流程.但定时开始事件有很大的局限性,比如时间.循环次数.循环间隔是必须要指定的,这对于一些根据实际状况,计算时间并启动的流程是无法处理的. 通过一系列的源码分析,最终找到了手动建立Job的方式方法,代码如下: // 时间计算 Date now = new Date(); // delay为相较当前时间,延时的时间变量 Date target = new Date(now.getTime() + delay * 60 * 100

SQL Server 创建作业系列问题

一.从IClassFactory为CLSID为{AA40D1D6-CAEF-4A56-B9BB-D0D3DC976BA2}的COM组件创建实例失败. 尊重原著作:本文转载自http://www.haogongju.net/art/2061733 问题描述 在“新建维护计划”时,报错:创建维护计划失败. 其他信息: 从 ICLassFactory 为CLSID为{17BCA6E8-A95D-497E-B2F9-AF6AA475916F}的COM组件创建实例失败,原因是出现以后错误: c001f01

ORACLE 创建作业JOB例子

--1.plsql中学习job   --学习job  --建表  create table test_job(para_date date);  commit;    insert into test_job values(sysdate);  commit;  select * from test_job;  --建立存贮过程   create or replace procedure test_jobproce   as  begin  insert into test_job values

sqlserver2008 R2 创建作业(定时任务)

如题: 第一步: 第二步: 第三步: 第四步: 第五步: 第六步: 第七步: 完成!!! 记得把服务打开.设置为自动启动,别重启服务器后没用了.