转自: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作业及调度创建的更多相关文章

  1. 如何跑通第一个 SQL 作业

    简介: 本文由阿里巴巴技术专家周凯波(宝牛)分享,主要介绍如何跑通第一个SQL. 一.SQL的基本概念 1.SQL 分类 SQL分为四类,分别是数据查询语言(DQL).数据操纵语言(DML).数据定义 ...

  2. 使用SQL Server Management Studio 创建作业备份数据库

    在项目中,经常需要备份数据库,如果能做到只需点个按钮(“开始备份数据库”按钮),然后什么都不管,数据库就自动备份好了,或者服务器上的数据库隔一段时间自动备份一次,那该多好啊. Sql server 的 ...

  3. 使用SQL Server Management Studio 创建数据库备份作业

    --完整备份,每周一次USE MasterGOdeclare @str varchar(100)set @str='D:\Weldon\DBBACK\FullBak'+replace(replace( ...

  4. 创建sql作业(JOB)

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

  5. OO第二次博客作业——电梯调度

    OO第二次博客作业——电梯调度 前言 最近三周,OO课程进入多线程学习阶段,主要通过三次电梯调度作业来学习.从单部电梯的傻瓜式调度到有性能要求的调度到多部电梯的调度,难度逐渐提升,对同学们的要求逐渐变 ...

  6. SQL Server COM 组件创建实例失败

    SQL Server COM 组件创建实例失败   SQL2008数据库总会出现从 IClassFactory 为 CLSID 为 {17BCA6E8-A95D-497E-B2F9-AF6AA4759 ...

  7. [转]使用Oracle SQL Developer连接数据库并创建用户

    本文转自:http://blog.csdn.net/xw13106209/article/details/6594738 1.使用sys账户创建数据库连接 安装Oracle 11g会自带一个叫做SQL ...

  8. MS SQL作业Schedule的限制注意事项

      最近遇到了一个关于MS SQL作业Schedule下有限制的特殊案例,有一个作业,用户要求执行的时间为:9:30,14:30,16:30, 19:00,于是我设置了两个Schedule,其中一个每 ...

  9. 利用Microsoft Sql Server Management studio 创建数据库的示例

    利用Microsoft Sql Server Management studio 创建数据库的示例方法如下:   一.打开安装好的Microsoft Sql Server Management stu ...

随机推荐

  1. elastaticresearch 学习过程

    1.在Windows上安装了es 2.在chrome上装了sense 3.尝试创建 es 的模板

  2. 源码中的哲学——通过构建者模式创建SparkSession

    spark2.2在使用的时候使用的是SparkSession,这个SparkSession创建的时候很明显的使用了创建者模式.通过观察源代码,简单的模拟了下,可以当作以后编码风格的参考: 官方使用 i ...

  3. getComputedStyle与currentStyle获取样式(style/class)

    今天看jQuery源码CSS部分,里面用到了currentStyle和getComputedStyle来获取外部样式. 因为elem.style.width只能获取elem的style属性里的样式,无 ...

  4. php解决json_encode输出GB2312中文问题 (数组)

    在 php 中使用 json_encode() 内置函数(php > 5.2)可以使用得 php 中数据可以与其它语言很好的传递并且使用它. 这个函数的功能是将数值转换成json数据存储格式. ...

  5. Vuex 源码学习(二)

    Vue加载后,将Vuex 加载到 Vue对象上后,初始化Store. (一) Store的参数的定义 其中 action 与 mutation 的订阅者 用 数组存储,而其属性都是用对象存储的. 考虑 ...

  6. MySQL迁移方案(后续再补充)

    出处:黑洞中的奇点 的博客 http://www.cnblogs.com/kelvin19840813/ 您的支持是对博主最大的鼓励,感谢您的认真阅读.本文版权归作者所有,欢迎转载,但请保留该声明. ...

  7. Micropython实例之TPYBoard来电显示功能演示

    一.TPYBoardV702介绍 TPYBoardV702是目前市面上唯一支持通信通信功能的MicroPython开发板:支持Python3.0及以上版本直接运行.支持GPS+北斗双模通信.GPRS通 ...

  8. svn conflict 冲突解决

    1. 同一处修改文件冲突 开发人员都知道代码管理工具是开发中一个必不可少的工具,这里也不废话详细介绍了.不管你个人喜欢git还是svn还是其他,但还有一大部分公司在使用svn做代码管理工具.这里详细介 ...

  9. OTCBTC上线币币交易

    我们在这里很高兴的宣布,OTCBTC 的币币交易区,即将在 2018/01/11 于 08:00 上线. 这个币币交易区,将会跟所有现有的交易所很不一样,我们将开放用户自主上币,且所有品种不收任何上架 ...

  10. OS.path部分函数的介绍

    OS.path模块中的部分函数的介绍 os.path.abspath(path) #返回绝对路径 os.path.basename(path) #返回文件名 os.path.commonprefix( ...