SQL作业及调度创建
转自:http://www.cnblogs.com/accumulater/p/6223909.html
--定义创建作业 转自http://hi.baidu.com/procedure/blog/item/7f959fb10d76f95d092302dd.html
DECLARE @jobid uniqueidentifier
EXEC msdb.dbo.sp_add_job
@job_name = N'作业名称',
@job_id = @jobid OUTPUT --定义作业步骤
DECLARE @sql nvarchar(400),@dbname sysname
SELECT @dbname=DB_NAME(), --作业步骤在当前数据库中执行
@sql=N'--作业步骤内容' --一般定义的是使用TSQL处理的作业,这里定义要执行的Transact-SQL语句
EXEC msdb.dbo.sp_add_jobstep
@job_id = @jobid,
@step_name = N'作业步骤名称',
@subsystem = 'TSQL', --步骤的类型,一般为TSQL
@database_name=@dbname,
@command = @sql --创建调度(使用后面专门定义的几种作业调度模板)
EXEC msdb..sp_add_jobschedule
@job_id = @jobid,
@name = N'调度名称',
@freq_type=4, --每天
@freq_interval=1, --指定每多少天发生一次,这里是1天.
@freq_subday_type=0x8, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
@freq_subday_interval=1, --重复周期数,这里每小时执行一次
@active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
@active_end_date = 99991231, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
@active_start_time = 00000, --作业执行的开始时间,格式为HHMMSS
@active_end_time = 235959 --作业执行的停止时间,格式为HHMMSS --添加目标服务器
DECLARE @servername sysname
SET @servername=CONVERT(nvarchar(128),SERVERPROPERTY(N'ServerName'))
EXEC msdb.dbo.sp_add_jobserver
@job_id = @jobid,
@server_name = @servername --使用当前SQL实例 --调度模板定义
--/*--日调度
EXEC msdb..sp_add_jobschedule
@job_id = @jobid,
@name = N'调度名称',
@freq_type=4, --每天
@freq_interval=1, --指定每多少天发生一次,这里是1天.
@freq_subday_type=0x8, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
@freq_subday_interval=1, --重复周期数,这里每小时执行一次
@active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
@active_end_date = 99991231, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
@active_start_time = 00000, --作业执行的开始时间,格式为HHMMSS
@active_end_time = 235959 --作业执行的停止时间,格式为HHMMSS
--*/ --/*--周调度
EXEC msdb.dbo.sp_add_jobschedule
@job_id = @jobid,
@name = N'调度名称',
@freq_type = 8, --每周
@freq_recurrence_factor = 1, --每多少周执行一次,这里是每周
@freq_interval = 62, --在星期几执行,由POWER(2,N)表示,N的值为0~6,代表星期日~星期六,如果指定两个,则将值相加,例如,值为65表示在星期天和星期日执行(POWER(2,0)+POWER(2,6))
@freq_subday_type = 0x8, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
@freq_subday_interval = 1, --重复周期数,这里每小时执行一次
@active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
@active_end_date = 99991231, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
@active_start_time = 00000, --作业执行的开始时间,格式为HHMMSS
@active_end_time = 235959 --作业执行的停止时间,格式为HHMMSS
--*/ --/*--月调度(每X个月的每月几号)
EXEC msdb.dbo.sp_add_jobschedule
@job_id = @jobid,
@name = N'调度名称',
@freq_type = 16, --每月
@freq_recurrence_factor = 2, --每多少月执行一次,这里是每2个月
@freq_interval = 2, --在执行月的第几天执行,这里是第2天
@freq_subday_type = 0x8, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
@freq_subday_interval = 1, --重复周期数,这里每小时执行一次
@active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
@active_end_date = 99991231, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
@active_start_time = 00000, --作业执行的开始时间,格式为HHMMSS
@active_end_time = 235959 --作业执行的停止时间,格式为HHMMSS
--*/ --/*--月调度(每X个月的相对时间)
EXEC msdb.dbo.sp_add_jobschedule
@job_id = @jobid,
@name = N'调度名称',
@freq_type = 32, --每月
@freq_recurrence_factor = 2, --每多少月执行一次,这里是每2个月
@freq_interval = 9, --在当月的那个时间执行,1~7=星期日至星期六,8=日 ,9=工作日,10=周末
@freq_relative_interval = 1, --在第几个相对时间执行,允许的值为1,2,4,8代表第1~4个相对时间,16表示最后一个相对时间
@freq_subday_type = 0x8, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
@freq_subday_interval = 1, --重复周期数,这里每小时执行一次
@active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
@active_end_date = 99991231, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
@active_start_time = 00000, --作业执行的开始时间,格式为HHMMSS
@active_end_time = 235959 --作业执行的停止时间,格式为HHMMSS
--*/ --/*--在特定时候执行的作业调度
EXEC msdb.dbo.sp_add_jobschedule
@job_id = @jobid,
@name = N'调度名称',
@freq_type = 64 --64=在SQLServerAgent 服务启动时运行,128=计算机空闲时运行
--*/ --/*--只执行一次的作业调度
EXEC msdb..sp_add_jobschedule
@job_id = @jobid,
@name = N'调度名称',
@freq_type=1, --仅执行一次
@active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
@active_start_time = 00000 --作业执行的开始时间,格式为HHMMSS
--*/ 自己写的一个通用存储过程: set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
go ALTER proc [dbo].[Formula_CreateJob]
@jobname varchar(100), --作业名称
@sql varchar(8000), --要执行的命令, --作业步骤内容,一般定义的是使用TSQL处理的作业,这里定义要执行的Transact-SQL语句
-- @serverName sysname='', --job server名
-- @dbname sysname='', --默认为当前的数据库名
@freqtype INT=4, --频率 4 天,8周,16 月调度(每X个月的每月几号 ,32 月调度(每X个月的相对时间)
-----------------------------------------------------------------------------
@freqInterval INT= 1,
--指定每多少天发生一次,这里是1天.
--在星期几执行,由POWER(2,N)表示,N的值为0~6,代表星期日~星期六,如果指定两个,则将值相加,例如,值为65表示在星期天和星期日执行(POWER(2,0)+POWER(2,6))
--在执行月的第几天执行,这里是第1天
--在当月的那个时间执行,1~7=星期日至星期六,8=日 ,9=工作日,10=周末
@freq_recurrenceFactor INT =1, --每多少月(周)执行一次,这里是每1
@freq_relativeInterval INT= 1, --在第几个相对时间执行,允许的值为1,2,4,8代表第1~4个相对时间,16表示最后一个相对时间 --每天频率
@freqSubdayType INT =1, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
@freqSubdayInterval INT =1, --重复周期数,例freqSubdayType为8,freqSubdayInterval为2,则每2个小时执行一次
--持续时间
@active_startDate NVARCHAR(20)= NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
@active_endDate NVARCHAR(20)='', --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
@active_startTime NVARCHAR(20)='', --作业执行的开始时间,格式为HHMMSS
@active_endTime NVARCHAR(20)='' --作业执行的停止时间,格式为HHMMSS AS
BEGIN --定义创建作业
DECLARE @jobid uniqueidentifier
EXEC msdb.dbo.sp_add_job
@job_name = @jobname,
@job_id = @jobid OUTPUT --定义作业步骤
DECLARE @dbname sysname
SELECT @dbname=DB_NAME() --作业步骤在当前数据库中执行
EXEC msdb.dbo.sp_add_jobstep
@job_id = @jobid,
@step_name = N'执行公式作业,生成费用明细',
@subsystem = 'TSQL', --步骤的类型,一般为TSQL
@database_name=@dbname,
@command = @sql --创建调度(使用后面专门定义的几种作业调度模板)
--@freqtype INT=4, --频率 4 天,8周,16 月调度(每X个月的每月几号 ,32 月调度(每X个月的相对时间)
IF @freqtype=4
BEGIN
EXEC msdb.dbo.sp_add_jobschedule
@job_id = @jobid,
@name = N'日调度,生成费用明细',
@freq_type=@freqtype, --每天
@freq_interval=@freqInterval, --指定每多少天发生一次,这里是1天.
@freq_subday_type=@freqSubdayType, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
@freq_subday_interval=@freqSubdayInterval, --重复周期数,这里每小时执行一次
@active_start_date = @active_startDate, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
@active_end_date = @active_endDate, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
@active_start_time = @active_startTime, --作业执行的开始时间,格式为HHMMSS
@active_end_time = @active_endTime --作业执行的停止时间,格式为HHMMSS END
IF @freqtype=8
BEGIN EXEC msdb.dbo.sp_add_jobschedule
@job_id = @jobid,
@name = N'周调度,生成费用明细',
@freq_type=@freqtype, --每周
@freq_recurrence_factor=@freq_recurrenceFactor,--每多少周执行一次,这里是每周
@freq_interval=@freqInterval, --在星期几执行,由POWER(2,N)表示,N的值为0~6,代表星期日~星期六,如果指定两个,则将值相加,例如,值为65表示在星期天和星期日执行(POWER(2,0)+POWER(2,6))
@freq_subday_type=@freqSubdayType, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
@freq_subday_interval=@freqSubdayInterval, --重复周期数,这里每小时执行一次
@active_start_date = @active_startDate, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
@active_end_date = @active_endDate, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
@active_start_time = @active_startTime, --作业执行的开始时间,格式为HHMMSS
@active_end_time = @active_endTime --作业执行的停止时间,格式为HHMMSS
END
IF @freqtype=16
BEGIN
EXEC msdb.dbo.sp_add_jobschedule
@job_id = @jobid,
@name = N'月调度,生成费用明细',
@freq_type=@freqtype, --每月
@freq_recurrence_factor=@freq_recurrenceFactor,--每多少周执行一次,这里是每周
@freq_interval=@freqInterval, --指定每多少天发生一次,这里是1天.
@freq_subday_type=@freqSubdayType, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
@freq_subday_interval=@freqSubdayInterval, --重复周期数,这里每小时执行一次
@active_start_date = @active_startDate, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
@active_end_date = @active_endDate, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
@active_start_time = @active_startTime, --作业执行的开始时间,格式为HHMMSS
@active_end_time = @active_endTime --作业执行的停止时间,格式为HHMMSS
END
IF @freqtype=32
BEGIN
EXEC msdb.dbo.sp_add_jobschedule
@job_id = @jobid,
@name = N'月调度,生成费用明细',
@freq_type=@freqtype, --每月
@freq_recurrence_factor=@freq_recurrenceFactor,--每多少周执行一次,这里是每周
@freq_interval=@freqInterval, --指定每多少天发生一次,这里是1天.
@freq_relative_interval = @freq_relativeInterval, --在第几个相对时间执行,允许的值为1,2,4,8代表第1~4个相对时间,16表示最后一个相对时间
@freq_subday_type=@freqSubdayType, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
@freq_subday_interval=@freqSubdayInterval, --重复周期数,这里每小时执行一次
@active_start_date = @active_startDate, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
@active_end_date = @active_endDate, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
@active_start_time = @active_startTime, --作业执行的开始时间,格式为HHMMSS
@active_end_time = @active_endTime --作业执行的停止时间,格式为HHMMSS
END --添加目标服务器
DECLARE @servername sysname
SET @servername=CONVERT(nvarchar(128),SERVERPROPERTY(N'ServerName'))
EXEC msdb.dbo.sp_add_jobserver
@job_id = @jobid,
@server_name = @servername --使用当前SQL实例 END
SQL作业及调度创建的更多相关文章
- 如何跑通第一个 SQL 作业
简介: 本文由阿里巴巴技术专家周凯波(宝牛)分享,主要介绍如何跑通第一个SQL. 一.SQL的基本概念 1.SQL 分类 SQL分为四类,分别是数据查询语言(DQL).数据操纵语言(DML).数据定义 ...
- 使用SQL Server Management Studio 创建作业备份数据库
在项目中,经常需要备份数据库,如果能做到只需点个按钮(“开始备份数据库”按钮),然后什么都不管,数据库就自动备份好了,或者服务器上的数据库隔一段时间自动备份一次,那该多好啊. Sql server 的 ...
- 使用SQL Server Management Studio 创建数据库备份作业
--完整备份,每周一次USE MasterGOdeclare @str varchar(100)set @str='D:\Weldon\DBBACK\FullBak'+replace(replace( ...
- 创建sql作业(JOB)
在SQL Server日常需求处理中,会遇到定时执行或统计数据的需求,这时我们可以通过作业(JOB)来处理,从而通过代理的方式来实现数据的自动处理.一下为SQL Server中创建作业的脚本,供大家参 ...
- OO第二次博客作业——电梯调度
OO第二次博客作业——电梯调度 前言 最近三周,OO课程进入多线程学习阶段,主要通过三次电梯调度作业来学习.从单部电梯的傻瓜式调度到有性能要求的调度到多部电梯的调度,难度逐渐提升,对同学们的要求逐渐变 ...
- SQL Server COM 组件创建实例失败
SQL Server COM 组件创建实例失败 SQL2008数据库总会出现从 IClassFactory 为 CLSID 为 {17BCA6E8-A95D-497E-B2F9-AF6AA4759 ...
- [转]使用Oracle SQL Developer连接数据库并创建用户
本文转自:http://blog.csdn.net/xw13106209/article/details/6594738 1.使用sys账户创建数据库连接 安装Oracle 11g会自带一个叫做SQL ...
- MS SQL作业Schedule的限制注意事项
最近遇到了一个关于MS SQL作业Schedule下有限制的特殊案例,有一个作业,用户要求执行的时间为:9:30,14:30,16:30, 19:00,于是我设置了两个Schedule,其中一个每 ...
- 利用Microsoft Sql Server Management studio 创建数据库的示例
利用Microsoft Sql Server Management studio 创建数据库的示例方法如下: 一.打开安装好的Microsoft Sql Server Management stu ...
随机推荐
- css自适应
一.顶部标题自适应 <html> <head> <title>顶部标题</title> <style> body{padding:0;mar ...
- Netty入门之HelloWorld
Netty系列入门之HelloWorld(一) 一. 简介 Netty is a NIO client server framework which enables quick and easy de ...
- MicroPython教程之TPYBoard开发板DIY红外寻迹小车
智能小车现在差不多是电子竞赛或者DIY中的主流了,寻迹,壁障,遥控什么的,相信大家也都见得很多了,这次就大家探讨一下寻迹小车的制作方法,不同于以往的是这次的程序不用C语言写,而是要使用python语言 ...
- Unity3d 动态加载场景物件与缓存池的使用
聊聊Unity3d动态加载场景物件那些事儿. 众所周知,在策划或美术设计完游戏场景地图后,一个场景中可能会存在成千上万个小的物件,比如石头,木箱子,油桶,栅栏等等等等,这些物件并不是游戏中的道具,仅仅 ...
- IRP的同步
应用层对设备的同步与异步操作 以WriteFile为例,一般的同步操作是调用WriteFile完成后,并不会返回,应用程序会在此处暂停,一直等到函数将数据写入文件中并正常返回,而异步操作则是调用Wri ...
- C#操作MongoDB的简单实例
最近比较忙,很久没更新了(虽然没人看,也没人在乎,也要记得be yourself), 前面分享了一些mongodb的安装和简单的语法,今天模仿支付宝首页的模块移动功能,用mongo做一个简单的后台实例 ...
- 阿里云正式上线移动直播问答解决方案,助力APP尽情“撒币”!
2018年伊始,互联网圈就刮起了一阵"大佬狂撒币,网友喜答题"的热潮.以映客芝士超人等为代表的直播问答平台,通过答题分奖金的互动模式,迅速引爆网络热点.随后,多个直播和视频平台也上 ...
- 使用mysql乐观锁解决并发问题
案例说明: 银行两操作员同时操作同一账户.比如A.B操作员同时读取一余额为1000元的账户,A操作员为该账户增加100元,B操作员同时为该账户扣除50元,A先提交,B后提交.最后实际账户余额为1000 ...
- COGS 862. 二进制数01串【dp+经典二分+字符串】
862. 二进制数01串 ★ 输入文件:kimbits.in 输出文件:kimbits.out 简单对比 时间限制:1 s 内存限制:128 MB USACO/kimbits(译 by ...
- [bzoj3233] [Ahoi2013]找硬币
一开始没什么思路...后来想到确定最大硬币面值就知道其他面值能取多少了..而且结果是可以由较小的面值转移过来的. f[i]表示最大面值为i时的最小硬币数.a[i]表示第i个物品的价钱. f[i]=mi ...