`
weimou66
  • 浏览: 1277991 次
文章分类
社区版块
存档分类
最新评论

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

/*--作业处理实例

根据sendTab的SendTime定制作业

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

--邹建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, --要处理的sendTab的id

@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

分享到:
评论

相关推荐

    \SQL Server 2008 定时作业的制定

    SQL Server 2008 定时作业的制定 SQL Server 2008 定时作业的制定是数据库管理员和开发人员经常需要进行的一项操作。通过定时作业,可以自动执行某些数据库操作,例如备份数据库、统计数据库、清理日志等。下面是 ...

    SQL Server 2005和2008定时作业的制定

    ### SQL Server 2005 和 2008 定时作业的制定 #### 一、概述 在 SQL Server 2005 和 2008 中,定时作业是一项非常重要的功能,它允许管理员设定一系列的任务在指定的时间自动执行。这对于数据备份、清理临时表、...

    定时备份SQL

    在IT行业中,数据库管理是至关重要的任务之一,而SQL(Structured Query Language)数据库的定时备份则是确保数据安全和业务连续性的关键环节。定时备份SQL旨在自动化数据库备份过程,以防止数据丢失,应对意外情况...

    添加作业-数据库定时自动备份

    2. **备份策略**:根据业务需求制定合理的备份频率和保留期限。 3. **测试恢复**:定期进行恢复测试,确保备份文件的完整性和可用性。 4. **安全性**:备份文件同样需要保护,避免未经授权的访问和修改。 5. **监控...

    SQL Server数据库自动异地备份方案分析与探讨.pdf

    在文章中,作者首先介绍了如何利用SQL Server作业实现本地定时自动备份数据库。这是自动异地备份的基础。具体操作步骤包括打开SQL Server Management Studio,启动SQL Server代理,新建作业,并为作业输入名称。然后...

    SQL自动备份1.zip

    然后,利用SQL Server的代理服务定时执行这些脚本。 3. 第三方工具:市面上有许多第三方工具,如Red Gate的SQL Backup,能简化SQL Server的备份工作,并提供高级功能如云备份、压缩和加密。 无论选择哪种方式,...

    数据库定时自动备份

    数据库定时自动备份是确保数据安全性...通过合理配置SQL Server Agent和制定合适的备份策略,可以确保数据安全,减少潜在损失。同时,备份策略应结合业务需求灵活调整,并持续监控和测试,以应对不断变化的环境和挑战。

    SQL Server数据库自动异地备份.pdf

    4. 启动SQL Server代理,使它执行“数据库维护计划”作业,并根据需要为作业制定具体的执行计划。 重复上述操作可以为其他六天制定相应的备份计划。每次制定的备份任务名称根据执行间隔进行适当改动,并将备份数据...

    oracle定时任务

    创建Oracle定时任务首先需要定义一个作业(JOB),这个作业可以是PL/SQL过程、包、存储过程,甚至可以是操作系统命令。使用DBMS_SCHEDULER包中的CREATE_JOB过程来创建一个新作业,例如: ```sql BEGIN DBMS_...

    sqlserver 面试时的考题

    **题目**: 如何监控50台服务器上的SQL Server作业状态? - **解析**: 监控多台服务器上的作业状态可以通过以下方式实现: - 在一台服务器上创建一个视图,通过链接服务器获取其他服务器上的作业活动信息。 - 使用T...

    BE备份SQL数据库的设置.pdf

    对于测试目的,可以选择“立即运行”,而在实际环境中,用户可以根据业务需求制定定时备份计划,例如每天、每周或在特定时间点执行。 总的来说,BE备份SQL数据库的设置是一个系统且详尽的过程,涉及到路径规划、...

    浅析SQL Server数据库的备份与还原.pdf

    定时备份是指在数据库管理器中预先设置作业,通过SQL Server Agent或其他计划工具,如数据库维护计划,按照设定的时间间隔,自动将数据库复制到指定的数据文件中。这种方法适合于对数据备份频率有固定要求的场景。 ...

    SQL Server 的备份策略应用.pdf

    而对于需要定时备份的场景,系统提供了自动备份的功能,它通过SQL Server Agent服务将备份操作设置为作业,并配置相应的执行计划,实现定期自动备份。如果需要调整备份时间间隔,只需重新执行一次自动备份操作即可。...

    浅谈SQL Server 2008中备份计划的实施.pdf

    通过上述步骤,管理员可以创建出一个自动化、定时执行的备份计划,以确保数据的及时备份和快速恢复,从而为企业的数据安全提供坚实的保障。 此外,文章还提到了维护计划与备份任务的配合使用,它能够提供更加灵活和...

    Spark . 无缝升级到 . 在唯品会的实践.docx

    该集群规模庞大,拥有约 2300 台物理服务器,每天运行超过 1.2 万个 Spark 定时作业和 8 万个 YARN 实例。此外,Spark Adhoc 日查询次数达到 9000 次左右。这些数据显示出 Spark 在唯品会大数据处理中的核心地位。 ...

    用户画像系统解决方案——作业流程调度.pdf

    通过对这些标签的分析,企业可以更深入地理解用户需求,制定个性化营销策略。 2. 用户标签指标体系:建立用户标签指标体系是用户画像的基础,包括基础属性标签、行为标签、偏好标签等,它们通过数据挖掘技术从大量...

    数据库备份教程

    - **自动化备份**:通过编写T-SQL脚本或使用SQL Server Agent作业来实现定时自动备份。 - **异地备份**:为提高数据安全性,建议将备份文件存储在不同的物理位置。 ### 总结 通过对SQL Server数据库备份过程的详细...

    plsql developer 7.0教程

    **作业定义编辑器**:讲解了如何设置定时任务,执行批处理作业或定期维护任务。 **队列定义编辑器**:指导用户设计消息队列,实现异步通信和负载均衡。 **用户定义编辑器**:提供了管理数据库用户账号的工具,包括...

    数据库的安装、配置和管理实习报告

    此外,通过SQL Server代理设置作业,定时执行脚本,减轻管理员的日常监控工作。 实习内容详细介绍了升级SQL Server 2000的过程,包括: ⑴ 数据库复制:通过中央发布服务器/分发服务器模式,使用“配置发布和分发...

Global site tag (gtag.js) - Google Analytics