SQL定时作业的制定

定时作业的制定 

企业管理器  
--管理  
--
SQL Server代理  
--
右键作业  
--
新建作业  
--
"常规"项中输入作业名称  
--
"步骤"项  
--
新建  
--
"步骤名"中输入步骤名  
--
"类型"中选择"Transact-SQL 脚本(TSQL)"  
--
"数据库"选择执行命令的数据库  
--
"命令"中输入要执行的语句:   
    EXEC 存储过程名 ...   

--确定  
--
"调度"项  
--
新建调度  
--
"名称"中输入调度名称  
--
"调度类型"中选择你的作业执行安排  
--
如果选择"反复出现"  
--
点"更改"来设置你的时间安排   


然后将SQL Agent服务启动,并设置为自动启动,否则你的作业不会被执行  

设置方法:  
我的电脑
--控制面板--管理工具--服务--右键 SQLSERVERAGENT--属性--启动类型--选择"自动启动"--确定. 

 

 

SQL2005 的设置参考:

SQL server 2005中建立备份自动化任务

http://543925535.blog.51cto.com/639838/168511

/*--创建作业过程代码

--邹建 2003.10(引用时请保留此信息)--
*/

/*--调用示例

--每月执行的作业
exec p_createjob @jobname='mm',@sql='select * from syscolumns',@freqtype='month'

--每周执行的作业
exec p_createjob @jobname='ww',@sql='select * from syscolumns',@freqtype='week'

--每日执行的作业
exec p_createjob @jobname='a',@sql='select * from syscolumns'

--每日执行的作业,每天隔4小时重复的作业
exec p_createjob @jobname='b',@sql='select * from syscolumns',@fsinterval=4

--
*/
if exists (select * from dbo.sysobjects where id = object_id(N'[dbo].[p_createjob]') and OBJECTPROPERTY(id, N'IsProcedure') = 1)
drop procedure [dbo].[p_createjob]
GO

create proc p_createjob
@jobname varchar(100),  --作业名称
@sql varchar(8000),   --要执行的命令
@dbname sysname='',   --默认为当前的数据库名
@freqtype varchar(6)='day', --时间周期,month 月,week 周,day 日
@fsinterval int=1,   --相对于每日的重复次数
@time int=170000   --开始执行时间,对于重复执行的作业,将从0点到23:59分
as
if isnull(@dbname,'')='' set @dbname=db_name()

--创建作业
exec msdb..sp_add_job @job_name=@jobname

--创建作业步骤
exec msdb..sp_add_jobstep @job_name=@jobname,
@step_name = '数据处理',
@subsystem = 'TSQL',
@database_name=@dbname,
@command = @sql,
@retry_attempts = 5, --重试次数
@retry_interval = 5  --重试间隔

--创建调度
declare @ftype int,@fstype int,@ffactor int
select @ftype=case @freqtype when 'day' then 4
    
when 'week' then 8
    
when 'month' then 16 end
,
@fstype=case @fsinterval when 1 then 0 else 8 end
if @fsinterval<>1 set @time=0
set @ffactor=case @freqtype when 'day' then 0 else 1 end

EXEC msdb..sp_add_jobschedule @job_name=@jobname,
@name = '时间安排',
@freq_type=@ftype ,      --每天,8 每周,16 每月
@freq_interval=1,     --重复执行次数
@freq_subday_type=@fstype,   --是否重复执行
@freq_subday_interval=@fsinterval--重复周期
@freq_recurrence_factor=@ffactor,
@active_start_time=@time     --下午17:00:00分执行

go


 

 

 

 

/*--作业处理实例

 

根据sendTabSendTime定制作业

并且在该作业完成时,可以自动删除作业

--邹建2004.04(引用请保留此信息)--*/

 

--示例

 

--测试表

create table sendTab(ID int identity(1,1),Name varchar(10)

,SendTime datetime,AcceptUnit varchar(10)

,SendUnit varchar(10),Content varchar(8000))

 

create table accepteTab(ID int identity(1,1),Name varchar(10)

,SendUnit varchar(10),AcceptUnit varchar(10),Content varchar(8000))

go

 

--创建处理的存储过程

create proc p_JobSet

@id int, --要处理的sendTabid

@is_delete bit=0 --是否仅删除,为则否,为则是

as

declare @dbname sysname,@jobname sysname

,@date int,@time int

 

select @jobname='定时发送作业_'+cast(@id as varchar)

,@date=convert(varchar,SendTime,112)

,@time=replace(convert(varchar,SendTime,108),':','')

from sendTab where id=@id

 

if exists(select 1 from msdb..sysjobs where name=@jobname)

exec msdb..sp_delete_job @job_name=@jobname 

 

if @is_delete=1 return

 

--创建作业

exec msdb..sp_add_job @job_name=@jobname,@delete_level=1

 

--创建作业步骤

declare @sql varchar(800)

select @sql='insert accepteTab(name,SendUnit,AcceptUnit,Content)

select name,AcceptUnit,SendUnit,Content from sendTab where id='

+cast(@id as varchar)

,@dbname=db_name()

 

exec msdb..sp_add_jobstep @job_name=@jobname,

@step_name = '发送处理步骤',

@subsystem = 'TSQL',

@database_name=@dbname,

@command = @sql,

@retry_attempts = 5, --重试次数

@retry_interval = 5 --重试间隔

 

--创建调度

EXEC msdb..sp_add_jobschedule @job_name = @jobname, 

@name = '时间安排',

@enabled = 1, 

@freq_type = 1, 

@active_start_date = @date,

@active_start_time = @time

 

-- 添加目标服务器

EXEC msdb.dbo.sp_add_jobserver 

@job_name = @jobname ,

@server_name = N'(local)' 

go

 

--创建处理的触发器(新增/修改)

create trigger tr_insert_update on sendTab

for insert,update

as

declare @id int

declare tb cursor local for select id from inserted

open tb

fetch next from tb into @id

while @@fetch_status=0

begin

exec p_JobSet @id

fetch next from tb into @id

end

close tb

deallocate tb

go

 

--创建处理的触发器(删除)

create trigger tr_delete on sendTab

for delete

as

declare @id int

declare tb cursor local for select id from deleted

open tb

fetch next from tb into @id

while @@fetch_status=0

begin

exec p_JobSet @id,1

fetch next from tb into @id

end

close tb

deallocate tb

go

 

--测试

 

--插入数据

insert sendTab

select '文书','2004/5/1 12:00:00','UnitA','UnitB','txt'

union all select '文书','2004/5/12 12:00:00','UnitA','UnitB','txt'

union all select '文书','2004/5/21 12:00:00','UnitA','UnitB','txt'

 

--修改

update sendTab set name='档案',SendTime='2004/5/1 15:00:00'

where id=1

 

--删除

delete sendtab where id=3

go

--删除测试

drop table sendTab,accepteTab

drop proc p_JobSet

 

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值