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 ...
随机推荐
- 在Maven Central发布中文API的Java库
原址: https://zhuanlan.zhihu.com/p/28024364 相关问题: 哪些Java库有中文命名的API? 且记下随想. 之前没有发布过, 看了SO上的推荐:Publish a ...
- CSS开发规范
虽然很久之前整理过一份简单的CSS规范,但是当时写的也不是很全面,有些细节也没有照顾到.记录一份较详细的版本,以备不时之需. 命名规范 [强制] class一律使用小写字母+下划线格式命名 例: cl ...
- 房上的猫:while循环与do-while循环,debug的调试运用
一.循环结构 1.循环不是无休止进行的,满足一定条件的时候循环才会继续,称为"循环条件",循环条件不满足的时候,循环退出 2.循环结构是反复进行相同的或类似的一系列操作,称为&qu ...
- Python的变量和常量
解释器执行Python的过程: (python3,c:/test.py) 1:启动python解释器(内存中). 2:将c:/test.py内容从硬盘读到内存中(这一步和文本编辑器是一样的). 3 ...
- Android OpenGL ES 入门系列(二) --- 环境搭建
转载请注明出处 本文出自Hansion的博客 本章介绍如何使用GLSurfaceView和GLSurfaceView.Renderer完成在Activity中的最简单实现. 1.在AndroidMan ...
- Mongodb常规操作【一】
Mongodb是一种比较常见的NOSQL数据库,数据库排名第四,今天介绍一下Net Core 下,常规操作. 首先下C# 版的驱动程序 "MongoDB.Driver",相关依赖包 ...
- thinkphp->add方法错误
$group_id=$model->add($add); 以上这句代码如果执行成功,返回它存储的id,但是,会有一种情况一直返回1. 代码完全没有问题,检查数据库发现有两个主键id,删除一个就O ...
- Scala 简介
Scala 特性 面向对象特性 Scala是一种纯面向对象的语言,每个值都是对象.对象的数据类型以及行为由类和特质描述. 类抽象机制的扩展有两种途径:一种途径是子类继承,另一种途径是灵活的混入机制.这 ...
- wc--Linux
这个命令的功能也很好记,因为它功能很有限: wc -c filename:显示一个文件的字节数 wc -m filename:显示一个文件的字符数 wc -l filename:显示一个文件的行数 w ...
- Linux 和Windows之间命令行实现目录或文件互传
在linux中,我们常用scp命令传输文件: 如以下实例,我们想把当前服务器文件abc.sql传输到192.168.1.1服务器上 我们可以执行以下命令: scp /home/person/hww/a ...