转自:http://www.cnblogs.com/accumulater/p/6223909.html

  1. --定义创建作业 转自http://hi.baidu.com/procedure/blog/item/7f959fb10d76f95d092302dd.html
  2. DECLARE @jobid uniqueidentifier
  3. EXEC msdb.dbo.sp_add_job
  4. @job_name = N'作业名称',
  5. @job_id = @jobid OUTPUT
  6.  
  7. --定义作业步骤
  8. DECLARE @sql nvarchar(400),@dbname sysname
  9. SELECT @dbname=DB_NAME(), --作业步骤在当前数据库中执行
  10. @sql=N'--作业步骤内容' --一般定义的是使用TSQL处理的作业,这里定义要执行的Transact-SQL语句
  11. EXEC msdb.dbo.sp_add_jobstep
  12. @job_id = @jobid,
  13. @step_name = N'作业步骤名称',
  14. @subsystem = 'TSQL', --步骤的类型,一般为TSQL
  15. @database_name=@dbname,
  16. @command = @sql
  17.  
  18. --创建调度(使用后面专门定义的几种作业调度模板)
  19. EXEC msdb..sp_add_jobschedule
  20. @job_id = @jobid,
  21. @name = N'调度名称',
  22. @freq_type=4, --每天
  23. @freq_interval=1, --指定每多少天发生一次,这里是1天.
  24. @freq_subday_type=0x8, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
  25. @freq_subday_interval=1, --重复周期数,这里每小时执行一次
  26. @active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
  27. @active_end_date = 99991231, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
  28. @active_start_time = 00000, --作业执行的开始时间,格式为HHMMSS
  29. @active_end_time = 235959 --作业执行的停止时间,格式为HHMMSS
  30.  
  31. --添加目标服务器
  32. DECLARE @servername sysname
  33. SET @servername=CONVERT(nvarchar(128),SERVERPROPERTY(N'ServerName'))
  34. EXEC msdb.dbo.sp_add_jobserver
  35. @job_id = @jobid,
  36. @server_name = @servername --使用当前SQL实例
  37.  
  38. --调度模板定义
  39. --/*--日调度
  40. EXEC msdb..sp_add_jobschedule
  41. @job_id = @jobid,
  42. @name = N'调度名称',
  43. @freq_type=4, --每天
  44. @freq_interval=1, --指定每多少天发生一次,这里是1天.
  45. @freq_subday_type=0x8, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
  46. @freq_subday_interval=1, --重复周期数,这里每小时执行一次
  47. @active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
  48. @active_end_date = 99991231, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
  49. @active_start_time = 00000, --作业执行的开始时间,格式为HHMMSS
  50. @active_end_time = 235959 --作业执行的停止时间,格式为HHMMSS
  51. --*/
  52.  
  53. --/*--周调度
  54. EXEC msdb.dbo.sp_add_jobschedule
  55. @job_id = @jobid,
  56. @name = N'调度名称',
  57. @freq_type = 8, --每周
  58. @freq_recurrence_factor = 1, --每多少周执行一次,这里是每周
  59. @freq_interval = 62, --在星期几执行,由POWER(2,N)表示,N的值为0~6,代表星期日~星期六,如果指定两个,则将值相加,例如,值为65表示在星期天和星期日执行(POWER(2,0)+POWER(2,6))
  60. @freq_subday_type = 0x8, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
  61. @freq_subday_interval = 1, --重复周期数,这里每小时执行一次
  62. @active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
  63. @active_end_date = 99991231, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
  64. @active_start_time = 00000, --作业执行的开始时间,格式为HHMMSS
  65. @active_end_time = 235959 --作业执行的停止时间,格式为HHMMSS
  66. --*/
  67.  
  68. --/*--月调度(每X个月的每月几号)
  69. EXEC msdb.dbo.sp_add_jobschedule
  70. @job_id = @jobid,
  71. @name = N'调度名称',
  72. @freq_type = 16, --每月
  73. @freq_recurrence_factor = 2, --每多少月执行一次,这里是每2个月
  74. @freq_interval = 2, --在执行月的第几天执行,这里是第2天
  75. @freq_subday_type = 0x8, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
  76. @freq_subday_interval = 1, --重复周期数,这里每小时执行一次
  77. @active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
  78. @active_end_date = 99991231, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
  79. @active_start_time = 00000, --作业执行的开始时间,格式为HHMMSS
  80. @active_end_time = 235959 --作业执行的停止时间,格式为HHMMSS
  81. --*/
  82.  
  83. --/*--月调度(每X个月的相对时间)
  84. EXEC msdb.dbo.sp_add_jobschedule
  85. @job_id = @jobid,
  86. @name = N'调度名称',
  87. @freq_type = 32, --每月
  88. @freq_recurrence_factor = 2, --每多少月执行一次,这里是每2个月
  89. @freq_interval = 9, --在当月的那个时间执行,1~7=星期日至星期六,8=日 ,9=工作日,10=周末
  90. @freq_relative_interval = 1, --在第几个相对时间执行,允许的值为1,2,4,8代表第1~4个相对时间,16表示最后一个相对时间
  91. @freq_subday_type = 0x8, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
  92. @freq_subday_interval = 1, --重复周期数,这里每小时执行一次
  93. @active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
  94. @active_end_date = 99991231, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
  95. @active_start_time = 00000, --作业执行的开始时间,格式为HHMMSS
  96. @active_end_time = 235959 --作业执行的停止时间,格式为HHMMSS
  97. --*/
  98.  
  99. --/*--在特定时候执行的作业调度
  100. EXEC msdb.dbo.sp_add_jobschedule
  101. @job_id = @jobid,
  102. @name = N'调度名称',
  103. @freq_type = 64 --64=在SQLServerAgent 服务启动时运行,128=计算机空闲时运行
  104. --*/
  105.  
  106. --/*--只执行一次的作业调度
  107. EXEC msdb..sp_add_jobschedule
  108. @job_id = @jobid,
  109. @name = N'调度名称',
  110. @freq_type=1, --仅执行一次
  111. @active_start_date = NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
  112. @active_start_time = 00000 --作业执行的开始时间,格式为HHMMSS
  113. --*/
  114.  
  115. 自己写的一个通用存储过程:
  116.  
  117. set ANSI_NULLS ON
  118. set QUOTED_IDENTIFIER ON
  119. go
  120.  
  121. ALTER proc [dbo].[Formula_CreateJob]
  122. @jobname varchar(100), --作业名称
  123. @sql varchar(8000), --要执行的命令, --作业步骤内容,一般定义的是使用TSQL处理的作业,这里定义要执行的Transact-SQL语句
  124. -- @serverName sysname='', --job server
  125. -- @dbname sysname='', --默认为当前的数据库名
  126. @freqtype INT=4, --频率 4 天,8周,16 月调度(每X个月的每月几号 ,32 月调度(每X个月的相对时间)
  127. -----------------------------------------------------------------------------
  128. @freqInterval INT= 1,
  129. --指定每多少天发生一次,这里是1天.
  130. --在星期几执行,由POWER(2,N)表示,N的值为0~6,代表星期日~星期六,如果指定两个,则将值相加,例如,值为65表示在星期天和星期日执行(POWER(2,0)+POWER(2,6))
  131. --在执行月的第几天执行,这里是第1
  132. --在当月的那个时间执行,1~7=星期日至星期六,8=日 ,9=工作日,10=周末
  133. @freq_recurrenceFactor INT =1, --每多少月(周)执行一次,这里是每1
  134. @freq_relativeInterval INT= 1, --在第几个相对时间执行,允许的值为1,2,4,8代表第1~4个相对时间,16表示最后一个相对时间
  135.  
  136. --每天频率
  137. @freqSubdayType INT =1, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
  138. @freqSubdayInterval INT =1, --重复周期数,例freqSubdayType8,freqSubdayInterval2,则每2个小时执行一次
  139. --持续时间
  140. @active_startDate NVARCHAR(20)= NULL, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
  141. @active_endDate NVARCHAR(20)='', --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
  142. @active_startTime NVARCHAR(20)='', --作业执行的开始时间,格式为HHMMSS
  143. @active_endTime NVARCHAR(20)='' --作业执行的停止时间,格式为HHMMSS
  144.  
  145. AS
  146. BEGIN
  147.  
  148. --定义创建作业
  149. DECLARE @jobid uniqueidentifier
  150. EXEC msdb.dbo.sp_add_job
  151. @job_name = @jobname,
  152. @job_id = @jobid OUTPUT
  153.  
  154. --定义作业步骤
  155. DECLARE @dbname sysname
  156. SELECT @dbname=DB_NAME() --作业步骤在当前数据库中执行
  157. EXEC msdb.dbo.sp_add_jobstep
  158. @job_id = @jobid,
  159. @step_name = N'执行公式作业,生成费用明细',
  160. @subsystem = 'TSQL', --步骤的类型,一般为TSQL
  161. @database_name=@dbname,
  162. @command = @sql
  163.  
  164. --创建调度(使用后面专门定义的几种作业调度模板)
  165. --@freqtype INT=4, --频率 4 天,8周,16 月调度(每X个月的每月几号 ,32 月调度(每X个月的相对时间)
  166. IF @freqtype=4
  167. BEGIN
  168. EXEC msdb.dbo.sp_add_jobschedule
  169. @job_id = @jobid,
  170. @name = N'日调度,生成费用明细',
  171. @freq_type=@freqtype, --每天
  172. @freq_interval=@freqInterval, --指定每多少天发生一次,这里是1天.
  173. @freq_subday_type=@freqSubdayType, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
  174. @freq_subday_interval=@freqSubdayInterval, --重复周期数,这里每小时执行一次
  175. @active_start_date = @active_startDate, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
  176. @active_end_date = @active_endDate, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
  177. @active_start_time = @active_startTime, --作业执行的开始时间,格式为HHMMSS
  178. @active_end_time = @active_endTime --作业执行的停止时间,格式为HHMMSS
  179.  
  180. END
  181. IF @freqtype=8
  182. BEGIN
  183.  
  184. EXEC msdb.dbo.sp_add_jobschedule
  185. @job_id = @jobid,
  186. @name = N'周调度,生成费用明细',
  187. @freq_type=@freqtype, --每周
  188. @freq_recurrence_factor=@freq_recurrenceFactor,--每多少周执行一次,这里是每周
  189. @freq_interval=@freqInterval, --在星期几执行,由POWER(2,N)表示,N的值为0~6,代表星期日~星期六,如果指定两个,则将值相加,例如,值为65表示在星期天和星期日执行(POWER(2,0)+POWER(2,6))
  190. @freq_subday_type=@freqSubdayType, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
  191. @freq_subday_interval=@freqSubdayInterval, --重复周期数,这里每小时执行一次
  192. @active_start_date = @active_startDate, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
  193. @active_end_date = @active_endDate, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
  194. @active_start_time = @active_startTime, --作业执行的开始时间,格式为HHMMSS
  195. @active_end_time = @active_endTime --作业执行的停止时间,格式为HHMMSS
  196. END
  197. IF @freqtype=16
  198. BEGIN
  199. EXEC msdb.dbo.sp_add_jobschedule
  200. @job_id = @jobid,
  201. @name = N'月调度,生成费用明细',
  202. @freq_type=@freqtype, --每月
  203. @freq_recurrence_factor=@freq_recurrenceFactor,--每多少周执行一次,这里是每周
  204. @freq_interval=@freqInterval, --指定每多少天发生一次,这里是1天.
  205. @freq_subday_type=@freqSubdayType, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
  206. @freq_subday_interval=@freqSubdayInterval, --重复周期数,这里每小时执行一次
  207. @active_start_date = @active_startDate, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
  208. @active_end_date = @active_endDate, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
  209. @active_start_time = @active_startTime, --作业执行的开始时间,格式为HHMMSS
  210. @active_end_time = @active_endTime --作业执行的停止时间,格式为HHMMSS
  211. END
  212. IF @freqtype=32
  213. BEGIN
  214. EXEC msdb.dbo.sp_add_jobschedule
  215. @job_id = @jobid,
  216. @name = N'月调度,生成费用明细',
  217. @freq_type=@freqtype, --每月
  218. @freq_recurrence_factor=@freq_recurrenceFactor,--每多少周执行一次,这里是每周
  219. @freq_interval=@freqInterval, --指定每多少天发生一次,这里是1天.
  220. @freq_relative_interval = @freq_relativeInterval, --在第几个相对时间执行,允许的值为1,2,4,8代表第1~4个相对时间,16表示最后一个相对时间
  221. @freq_subday_type=@freqSubdayType, --重复方式,0x1=在指定的时间,0x4=多少分钟,0x8=多少小时执行一次
  222. @freq_subday_interval=@freqSubdayInterval, --重复周期数,这里每小时执行一次
  223. @active_start_date = @active_startDate, --作业执行的开始日期,为NULL时表示当前日期,格式为YYYYMMDD
  224. @active_end_date = @active_endDate, --作业执行的停止日期,默认为99991231,格式为YYYYMMDD
  225. @active_start_time = @active_startTime, --作业执行的开始时间,格式为HHMMSS
  226. @active_end_time = @active_endTime --作业执行的停止时间,格式为HHMMSS
  227. END
  228.  
  229. --添加目标服务器
  230. DECLARE @servername sysname
  231. SET @servername=CONVERT(nvarchar(128),SERVERPROPERTY(N'ServerName'))
  232. EXEC msdb.dbo.sp_add_jobserver
  233. @job_id = @jobid,
  234. @server_name = @servername --使用当前SQL实例
  235.  
  236. 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. 在Maven Central发布中文API的Java库

    原址: https://zhuanlan.zhihu.com/p/28024364 相关问题: 哪些Java库有中文命名的API? 且记下随想. 之前没有发布过, 看了SO上的推荐:Publish a ...

  2. CSS开发规范

    虽然很久之前整理过一份简单的CSS规范,但是当时写的也不是很全面,有些细节也没有照顾到.记录一份较详细的版本,以备不时之需. 命名规范 [强制] class一律使用小写字母+下划线格式命名 例: cl ...

  3. 房上的猫:while循环与do-while循环,debug的调试运用

    一.循环结构 1.循环不是无休止进行的,满足一定条件的时候循环才会继续,称为"循环条件",循环条件不满足的时候,循环退出 2.循环结构是反复进行相同的或类似的一系列操作,称为&qu ...

  4. Python的变量和常量

    解释器执行Python的过程:   (python3,c:/test.py) 1:启动python解释器(内存中). 2:将c:/test.py内容从硬盘读到内存中(这一步和文本编辑器是一样的). 3 ...

  5. Android OpenGL ES 入门系列(二) --- 环境搭建

    转载请注明出处 本文出自Hansion的博客 本章介绍如何使用GLSurfaceView和GLSurfaceView.Renderer完成在Activity中的最简单实现. 1.在AndroidMan ...

  6. Mongodb常规操作【一】

    Mongodb是一种比较常见的NOSQL数据库,数据库排名第四,今天介绍一下Net Core 下,常规操作. 首先下C# 版的驱动程序 "MongoDB.Driver",相关依赖包 ...

  7. thinkphp->add方法错误

    $group_id=$model->add($add); 以上这句代码如果执行成功,返回它存储的id,但是,会有一种情况一直返回1. 代码完全没有问题,检查数据库发现有两个主键id,删除一个就O ...

  8. Scala 简介

    Scala 特性 面向对象特性 Scala是一种纯面向对象的语言,每个值都是对象.对象的数据类型以及行为由类和特质描述. 类抽象机制的扩展有两种途径:一种途径是子类继承,另一种途径是灵活的混入机制.这 ...

  9. wc--Linux

    这个命令的功能也很好记,因为它功能很有限: wc -c filename:显示一个文件的字节数 wc -m filename:显示一个文件的字符数 wc -l filename:显示一个文件的行数 w ...

  10. Linux 和Windows之间命令行实现目录或文件互传

    在linux中,我们常用scp命令传输文件: 如以下实例,我们想把当前服务器文件abc.sql传输到192.168.1.1服务器上 我们可以执行以下命令: scp /home/person/hww/a ...