用户名:
密 码: 记住
您当前的位置:首页 > 网络编程 > sqlserver教程

如何在SQL Server和Oracle中创建job

时间:2014-11-30  来源:互联网  作者:佚名
西部数据-基于云计算领先的云服务器服务提供商,12年老品牌、全国3强。专业提供西数云主机虚拟主机域名注册VPS主机西数云服务器等,30余万个网站及100余万个域名用户的共同选择!云主机45元起,新注册用户免费领30元主机优惠码,立即领取

  有的时候,我们可能需要在数据库中设定一些自动执行的任务(job),以此来自动完成一些包括统计、备份方面的需求,下面就简单说明一下有关ms server和Oracle(Oracle培训 )两种数据库中如何新建自动任务。

  首先说下ms server,因为我也是新手,所以首先选择了使用企业管理器进行任务设定,然后再导出设计完毕的任务脚本,这样就可以在其他数据库中直接通过执行脚本的 形式来新建任务了(需要适当修改其中的一些任务名称和数据库名称等值),下面说下具体的操作步骤以及获得的任务脚本:

  1. 保证启动ms server的“SQL(SQL Server培训 mySQL培训 ) Server代理服务”(即agent service)

  2. 打开企业管理器 -> 连接数据服务器 -> 右键“SQL Server agent”节点下的“jobs”,选择“New Job”,在详细任务页面,我们会看到很多的设定选项:包括“常规”、“步骤”、“计划”、“警报”、“通知”和“目标”等,在这里我们可以进行非常详细 的任务设定,因为我要做的很简单,就是按时执行数据库中的某一个存储过程,所以只是简单地设定了一下常规、步骤和计划三项中的内容,其中我们通过步骤来设 定我们要进行的数据库操作和顺序,然后再通过“计划”来设定具体的操作方案,相比直接写sql语句来说,显得更加的容易些,比较适合于初学者。

  3. 右键选择我们刚刚创建成功的job,选择“Script job as -> CREATE TO”,选择把脚本存放到文件或者直接通过编辑器打开,然后再进行保存均可。我们可以看到系统自动生成的脚本看起来颇为复杂,因为其将其中的设定参数均进 行了设定,可能通过sql脚本可以省略很多的默认参数,但我们可以清晰地看到job创建的几个关键步骤。个人示例的sql脚本如后面附。经过精简后的代码 如下:

  复制代码 代码如下:


  DECLARE @jobId BINARY(16)
  --create the job
  EXEC msdb.dbo.sp_add_job @job_name = 'update table of Sys_PageInfo',
  @job_id = @jobId OUTPUT
  --create the step of the job
  EXEC msdb.dbo.sp_add_jobstep @job_id = @jobId,
  @step_name = 'just one step',
  @subsystem = 'TSQL',
  @command = 'EXEC dbo.BatchUpdateArchListTotalNum',
  @database_name=N'Exchanger_2'
  --create the schedual of the job
  EXEC msdb.dbo.sp_add_jobschedule @job_id = @jobId,
  @name = 'the schedual',
  @freq_type = 4,
  @freq_interval = 1,
  @active_start_time = 10000
  --create the server of the job
  EXEC msdb.dbo.sp_add_jobserver @job_id = @jobId, @server_name = N'(local)'

  下面再看看oracle中是如何创建job的,这次我们直接使用sql脚本进行创建,一些常用的sql语句如下:

  一、查看数据库中的任务


  select * from user_jobs

 二、删除数据库中指定的任务


  begin
  dbms_job.remove(50);
  end;

  三、创建一个每隔5分钟执行一次的任务


  DECLARE
  jobid NUMBER;
  BEGIN
  SYS.DBMS_JOB.SUBMIT(job => jobid,
  what => 'BatchUpdateArchListTotalNum();', // 存储过程如果没有参数,可以省略括号,但是不能省略分号
  next_date => sysdate,
  interval => 'sysdate+1/24/12');
  COMMIT;
  END;

  附:SQL server任务脚本:

  复制代码 代码如下:


  USE [msdb]
  GO
  /****** 对象: Job [更新] 脚本日期: 05/12/2009 18:14:14 ******/
  BEGIN TRANSACTION
  DECLARE @ReturnCode INT
  SELECT @ReturnCode = 0
  /****** 对象: JobCategory [Database Maintenance] 脚本日期: 05/12/2009 18:14:14 ******/
  IF NOT EXISTS (SELECT name FROM msdb.dbo.syscategories WHERE name=N'Database Maintenance' AND category_class=1)

  BEGIN
  EXEC @ReturnCode = msdb.dbo.sp_add_category @class=N'JOB', @type=N'LOCAL', @name=N'Database Maintenance'
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
  END
  DECLARE @jobId BINARY(16)
  EXEC @ReturnCode = msdb.dbo.sp_add_job @job_name=N'job名称',
  @enabled=0,
  @notify_level_eventlog=0,
  @notify_level_email=0,
  @notify_level_netsend=0,
  @notify_level_page=0,
  @delete_level=0,
  @description=N'无描述。',
  @category_name=N'Database Maintenance',
  @owner_login_name=N'sa', @job_id = @jobId OUTPUT
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
  /****** 对象: Step [更新Sys_PageInfo表的内容] 脚本日期: 05/12/2009 18:14:15 ******/
  EXEC @ReturnCode = msdb.dbo.sp_add_jobstep @job_id=@jobId, @step_name=N'操作步骤名称',

  @step_id=1,
  @cmdexec_success_code=0,
  @on_success_action=1,
  @on_success_step_id=0,
  @on_fail_action=2,
  @on_fail_step_id=0,
  @retry_attempts=0,
  @retry_interval=0,
  @os_run_priority=0, @subsystem=N'TSQL',
  @command=N'EXEC dbo.BatchUpdateArchListTotalNum',
  @database_name=N'Exchanger_2',
  @database_user_name=N'dbo',
  @flags=0
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
  EXEC @ReturnCode = msdb.dbo.sp_update_job @job_id = @jobId, @start_step_id = 1
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
  EXEC @ReturnCode = msdb.dbo.sp_add_jobschedule @job_id=@jobId, @name=N'计划名称',
  @enabled=1,
  @freq_type=4,
  @freq_interval=1,
  @freq_subday_type=1,
  @freq_subday_interval=1,
  @freq_relative_interval=0,
  @freq_recurrence_factor=0,
  @active_start_date=20090512,
  @active_end_date=99991231,
  @active_start_time=0,
  @active_end_time=235959
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
  EXEC @ReturnCode = msdb.dbo.sp_add_jobserver @job_id = @jobId, @server_name = N'(local)'
  IF (@@ERROR <> 0 OR @ReturnCode <> 0) GOTO QuitWithRollback
  COMMIT TRANSACTION
  GOTO EndSave
  QuitWithRollback:
  IF (@@TRANCOUNT > 0) ROLLBACK TRANSACTION
  EndSave:
来顶一下
返回首页
返回首页
推荐资讯
从零开始学ASP.NET-基础篇第1/7页 从零开始学ASP.NET-基础篇第1/7页第一天 学习目的: 掌握最基本的Label、TextBox、Button控件
ASP.NET入门数据篇 ASP.NET入门数据篇对于网站编程的初学者来说,总是会上网找些源码来看,但久而
相关文章
栏目更新
栏目热门