SQL作业的操作全
--定义创建作业 转自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 介绍和操作
1.什么是SQL SQL的全称是“结构话查询语句”(Structured Query Language ),是1974年有Boyce和chamberlin 提出来的.经过多年的发展,SQL语言已经成为 ...
- 如何跑通第一个 SQL 作业
简介: 本文由阿里巴巴技术专家周凯波(宝牛)分享,主要介绍如何跑通第一个SQL. 一.SQL的基本概念 1.SQL 分类 SQL分为四类,分别是数据查询语言(DQL).数据操纵语言(DML).数据定义 ...
- jquery autocomplete实现读取sql数据库自动补全TextBox
转自我本良人 原文 jquery autocomplete实现读取sql数据库自动补全TextBox 项目需要这样子一个功能,其他部门提的意见,只好去实现了哦,搞了好久才弄出来,分享一下. 1.前台页 ...
- Eclipse连接到My sql数据库之前操作
Eclipse连接到My sql数据库之前操作 1:首先是安装My sql数据库(为了减少你的麻烦,按照下面的连接,下载即可)百度云链接:http://pan.baidu.com/s/1mitWmbm ...
- SQL大数据操作统计
SQL大数据操作统计 1:select count(*) from table的区别SELECT object_name(id) as TableName,indid,rows,rowcnt FROM ...
- sql/plus 常用操作
一.sys用户和system用户Oracle安装会自动的生成sys用户和system用户(1).sys用户是超级用户,具有最高权限,具有sysdba角色,有create database的权限,该用户 ...
- js系列教程1-数组操作全解
全栈工程师开发手册 (作者:栾鹏) 快捷链接: js系列教程1-数组操作全解 js系列教程2-对象和属性全解 js系列教程3-字符串和正则全解 js系列教程4-函数与参数全解 js系列教程5-容器和算 ...
- jquery系列教程2-style样式操作全解
全栈工程师开发手册 (作者:栾鹏) 快捷链接: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件 ...
- jquery系列教程4-事件操作全解
点击打开: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件操作全解 jquery系列教程5-动 ...
随机推荐
- 和我一起学python,基本概念 (life is short ,we need python)
作者:tobecrazy 出处:http://www.cnblogs.com/tobecrazy 欢迎转载,转载请注明出处.thank you! 基本概念 : 常量: 常量名全部大写,如PI 变量: ...
- Java for LeetCode 211 Add and Search Word - Data structure design
Design a data structure that supports the following two operations: void addWord(word)bool search(wo ...
- SQL触发器中若取到null值可能引发的问题
declare @code varchar(20), @cs varchar(20),@zc varchar(20)set @cs='('+@cs+'*'+@zc+')'print '字符'+@csi ...
- js闭包问题
function picLinkInit(parentClassName, imgW, imgH, childClassObjs) { var $match = $(parentClassName); ...
- 深入浅出JMS(一)——JMS简介
如果手机只能进行实时通话,没有留言和短信功能会怎么样?一个电话打过来,正好没有来得及接上,那么这个电话要传递的信息肯定就收不到了.为什么不能先将信息存下来,当用户需要查看信息的时候再去获得信息呢?伴随 ...
- oracle触发器设置uuid变量
create or replace trigger tri_org_department after insert or update on bjlt.sys_org for each row dec ...
- window.parent 与 window.opener
window.parent针对iframe,window.opener针对window.open 父页面parent.jsp: <%@ page language="java" ...
- 微信支付官方.net版之坑你没商量
最近开始弄支付这块,先是支付宝手机网站支付,也是坑了我许久,不过还好,问题不大. 让我们看看微信支付有多少坑 微信商户平台,你们知道么(我前天才知道,别笑我) 登录地址:https://mch.wei ...
- java 中的一个项目如何做到访问另一个项目的一个方法 或者 页面
两种方法:1.将一个项目打成jar包,第二个项目进行导入该jar包,就可以使用第一个项目里的类方法属性等2.将第一个项目发布出去,然后第二个项目调用,所谓发布出去就是开发远程接口,允许其他人调用.
- python 中time模块使用
在开始之前,首先要说明这几点: 1.在Python中,通常有这几种方式来表示时间:1)时间戳 2)格式化的时间字符串 3)元组(struct_time)共九个元素.由于Python的time模块实现主 ...