`
jimmy9495
  • 浏览: 300608 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
文章分类
社区版块
存档分类
最新评论

导入数据库设置不自动执行JOB

阅读更多
原帖由 silent2916 于 2011-3-11 15:22 发表
具体语句需要怎么写啊?请指教!因为我们需要每个月更新一次测试库,搞得每导一次就有JOB导入,而且JOB还会自动发邮件,直接影响生产啊!

是IMP,还是IMPDP?

若是前者,把JOB PROCESS 这个参数设置为 0 即可,若是后者,IMPDP时直接EXCLUDE


以上引自:http://www.itpub.net/forum.php?mod=viewthread&tid=1397736&highlight=
以下引自:http://blog.csdn.net/tianlincao/article/details/6155093
Oracle job说明 .

初始化相关参数job_queue_processes 
  alter system set job_queue_processes=39 scope=spfile;//最大值不能超过1000 ;job_queue_interval = 10 //调度作业刷新频率秒为单位
  job_queue_process 表示oracle能够并发的job的数量,可以通过语句
  show parameter job_queue_process;
  来查看oracle中job_queue_process的值。当job_queue_process值为0时表示全部停止oracle的job,
可以通过语句 ALTER SYSTEM SET job_queue_processes = 10;
  来调整启动oracle的job。
  相关视图:
  dba_jobs
  all_jobs
  user_jobs
  dba_jobs_running 包含正在运行job相关信息
  -------------------------
  提交job语法:
  begin
  sys.dbms_job.submit(job => :job,
   what => 'P_CLEAR_PACKBAL;',
   next_date => to_date('04-08-2008 05:44:09', 'dd-mm-yyyy hh24:mi:ss'),
   interval => 'sysdate+ 1/360');
  commit;
  end;
  /
  -------------------------
  创建JOB
  variable jobno number;
  begin
  dbms_job.submit(:jobno, 'P_CRED_PLAN;',SYSDATE,'SYSDATE+1/2880',TRUE);
  commit;
  运行JOB
  SQL> begin
   dbms_job.run(:job1);
   end;
   /
  删除JOB
  SQL> begin
   dbms_job.remove(:job1);
   end;
   /
  DBA_JOBS
  ===========================================
  字段(列) 类型 描述
  JOB NUMBER 任务的唯一标示号
  LOG_USER VARCHAR2(30) 提交任务的用户
  PRIV_USER VARCHAR2(30) 赋予任务权限的用户
  SCHEMA_USER VARCHAR2(30) 对任务作语法分析的用户模式
  LAST_DATE DATE 最后一次成功运行任务的时间
  LAST_SEC VARCHAR2(8) 如HH24:MM:SS格式的last_date日期的小时,分钟和秒
  THIS_DATE DATE 正在运行任务的开始时间,如果没有运行任务则为null
  THIS_SEC VARCHAR2(8) 如HH24:MM:SS格式的this_date日期的小时,分钟和秒
  NEXT_DATE DATE 下一次定时运行任务的时间
  NEXT_SEC VARCHAR2(8) 如HH24:MM:SS格式的next_date日期的小时,分钟和秒
  TOTAL_TIME NUMBER 该任务运行所需要的总时间,单位为秒
  BROKEN VARCHAR2(1) 标志参数,Y标示任务中断,以后不会运行
  INTERVAL VARCHAR2(200) 用于计算下一运行时间的表达式
  FAILURES NUMBER 任务运行连续没有成功的次数
  WHAT VARCHAR2(2000) 执行任务的PL/SQL块
  CURRENT_SESSION_LABEL RAW MLSLABEL 该任务的信任Oracle会话符
  CLEARANCE_HI RAW MLSLABEL 该任务可信任的Oracle最大间隙
  CLEARANCE_LO RAW MLSLABEL 该任务可信任的Oracle最小间隙
  NLS_ENV VARCHAR2(2000) 任务运行的NLS会话设置
  MISC_ENV RAW(32) 任务运行的其他一些会话参数
  --------------------------
  描述 INTERVAL参数值
  每天午夜12点 'TRUNC(SYSDATE + 1)'
  每天早上8点30分 'TRUNC(SYSDATE + 1) + (8*60+30)/(24*60)'
  每星期二中午12点 'NEXT_DAY(TRUNC(SYSDATE ), ''TUESDAY'' ) + 12/24'
  每个月第一天的午夜12点 'TRUNC(LAST_DAY(SYSDATE ) + 1)'
  每个季度最后一天的晚上11点 'TRUNC(ADD_MONTHS(SYSDATE + 2/24, 3 ), 'Q' ) -1/24'
  每星期六和日早上6点10分 'TRUNC(LEAST(NEXT_DAY(SYSDATE, ''SATURDAY"), NEXT_DAY(SYSDATE, "SUNDAY"))) + (6×60+10)/(24×60)'
  --------------------------
  1:每分钟执行
  Interval => TRUNC(sysdate,'mi') + 1/ (24*60)
  2:每天定时执行
  例如:每天的凌晨1点执行
  Interval => TRUNC(sysdate) + 1 +1/ (24)
  3:每周定时执行
  例如:每周一凌晨1点执行
  Interval => TRUNC(next_day(sysdate,'星期一'))+1/24
  4:每月定时执行
  例如:每月1日凌晨1点执行
  Interval =>TRUNC(LAST_DAY(SYSDATE))+1+1/24
  5:每季度定时执行
  例如每季度的第一天凌晨1点执行
  Interval => TRUNC(ADD_MONTHS(SYSDATE,3),'Q') + 1/24
  6:每半年定时执行
  例如:每年7月1日和1月1日凌晨1点
  Interval => ADD_MONTHS(trunc(sysdate,'yyyy'),6)+1/24
  7:每年定时执行
  例如:每年1月1日凌晨1点执行
  Interval =>ADD_MONTHS(trunc(sysdate,'yyyy'),12)+1/24
实际应用:
Shlhdb中
--以下脚本运行方式 放文件在c盘根目录
--cmd
--sqlplus shlhdb/shlhdb
--@c:/pz_ztt.txt
create or replace procedure pro_pz_ztt
is
--v number;
begin
insert into pz_ztt
select tcm,to_char(sysdate,'yyyy')-1 nf,ztm,pic
from pz_ztt where nf=(select max(to_number(nf)) from pz_ztt) and nf!=(select to_char(
sysdate,'yyyy')-1 from dual);
commit;
end pro_pz_ztt;
/
variable job number;
begin
  sys.dbms_job.submit(job => :job,
  what => 'pro_pz_ztt;',
  next_date => sysdate,
  interval => 'ADD_MONTHS(trunc(sysdate,''yyyy''),12)+1/24');
  commit;
end;
/
begin
dbms_job.run(:job);
end;
/





设置Oracle job 按指定时间只执行一次:

SQL> variable job1 number;
SQL> begin
  2  dbms_job.submit(:job1,'myproc;',to_date('2011-01-20 16:42:00','yyyy-mm-dd hh24:mi:ss'),'null');
  3  commit;
  4  end;
  5  /



而且job执行完成后会自动删除该job(oracle 10g)。

分享到:
评论

相关推荐

    本地文件导入数据库(含备份和删除)

    当我们需要将本地文件导入数据库时,通常会遵循一定的步骤以确保数据的完整性和安全性。本篇文章将详细阐述如何将本地文件导入数据库,以及在导入后如何进行备份和删除原文件。 首先,我们来了解一下“本地文件导入...

    将Excel中数据导入到数据库中

    7. **自动化流程**:为了提高效率,可以将上述过程封装为脚本或工具,实现定期自动从Excel导入数据到数据库,例如通过Windows计划任务、Linux cron job或编程语言的定时任务。 总之,将Excel数据导入数据库是一个...

    将Excel 数据导入到到数据库

    - 使用PowerShell读取Excel,结合SQL Server的SMO(Server Management Objects)库,将数据导入数据库。 4. **VBA宏** - 在Excel中编写VBA代码,直接与数据库交互,将数据插入到指定的表。 三、自动化流程 1. **...

    自动导入EXCEL程序

    自动导入Excel程序是企业信息化中不可或缺的部分,特别是在数据密集型业务中,如数据分析、报表生成和数据库填充。熟练掌握这项技术,可以帮助IT专业人员提高工作效率,减少人为错误,并支持企业的数据驱动决策。

    基于PHP的faisunSQL自导入数据库备份程序(UTF-8版)源码.zip

    这是一个使用PHP编程语言编写的程序,其主要功能是自动导入数据库备份。"faisunSQL"很可能是该程序的特定名称或作者的标识。此外,"UTF-8版"强调了源码文件的字符编码格式,这意味着程序在处理文本数据时将遵循UTF-8...

    oracle 数据库自动备份工具

    总之,"Oracle 数据库自动备份工具"是确保数据安全不可或缺的一部分,它可以帮助管理员有效地管理和执行数据库备份任务,降低因数据丢失带来的风险。通过深入理解和正确使用这类工具,可以大大提高数据库管理的效率...

    命令行导入导出Oracle数据库操作

    相比于图形界面工具(如Oracle SQL Developer或Oracle Enterprise Manager),通过命令行来进行Oracle数据库的导入导出操作不仅更为高效快捷,而且在自动化运维场景下具有更大的灵活性。本文将详细介绍如何利用`...

    PHP实例开发源码-faisunSQL自导入数据库备份程序(UTF-8版).zip

    该压缩包文件“PHP实例开发源码-faisunSQL自导入数据库备份程序(UTF-8版).zip”是一个包含PHP源代码的项目,主要用于实现自动导入和备份数据库的功能。这个程序可能对那些需要管理和保护其数据库数据的Web开发者非常...

    数据库的导入导出

    ### 数据库的导入导出详解 #### 一、概述 在数据库管理中,数据的导入导出是一项非常重要的操作,特别是在进行数据迁移、备份恢复等场景下。本文将重点介绍Oracle数据库中的导入导出操作,主要包括表空间的创建...

    excel数据导入方法

    这个功能对于需要定期或重复导入数据的场景非常有用,只需通过DOS命令行执行预先设定好的job脚本,就能自动化完成数据导入任务,大大提高了工作效率。 另一个显著特性是,用户可以通过SQL语句来筛选源表中的部分...

    oracle数据库自动备份脚本带说明

    为了安全起见,这个脚本应该配置为定期任务,例如通过Windows的任务计划程序或Linux的cron job,以确保在固定的时间点自动执行。此外,为了验证备份的完整性,应定期进行恢复测试。 总的来说,`backup.bat`脚本是一...

    Kettle生成1亿条数据导入oracle

    在这个案例中,它可能是负责整个流程调度和监控的部分,确保生成数据和导入数据库的操作按照预定的时间和顺序执行。 - "生成亿级随机数据.ktr":这是Kettle的转换文件(Transformation),直接执行数据生成的任务。...

    Oracle数据库还原操作

    如果在执行导入操作时遇到错误ORA-31684(用户已经存在),则可能需要先删除已存在的用户再重新执行导入操作。 通过以上步骤,我们可以有效地进行Oracle数据库的还原操作,包括创建必要的表空间、用户及其权限配置...

    精彩实例:51job数据库系统架构实践

    利用crontab和shell脚本自动执行sar、iostat等命令收集数据;还使用Oracle自带的工具如v$_xxx、dba_xxx等进行数据库性能监控;并通过AWR报告对数据库的性能进行深入分析。 - **性能监控示例**: - **主机性能监控*...

    Oracle数据库恢复管理器及特殊包应用 (1)

    为了解决这个问题,Oracle引入了DBMS_JOB包,这是一个内置的PL/SQL包,用于安排存储过程和其他PL/SQL块的自动执行。通过DBMS_JOB,DBA可以设置定时任务,让系统在特定时间自动运行备份脚本或者数据处理过程,从而...

    PLSQL,PLSQL数据库客户端

    5. **数据管理**:浏览表结构,插入、更新、删除数据,执行数据导出导入等操作。 6. **版本控制集成**:与Git等版本控制系统集成,管理PLSQL代码的版本。 7. **性能分析**:通过执行计划、调用堆栈等工具分析代码...

    4、Sqoop job任务

    `--create testsqoopjob` 创建了一个名为testsqoopjob的job,`--import` 表示导入操作,接着是连接数据库的相关参数,`--target-dir` 指定了HDFS上的目标目录,`--table person` 指定了要导入的表,`--m 1` 设置了...

    第一个数据库项目

    8. **自动化工具**:利用脚本或自动化工具(如cron job)定期执行数据库维护任务,如数据导入导出、备份恢复等。 9. **源码管理**:如果源码是用编程语言编写的,可能涉及到版本控制工具如Git,用于协同开发和版本...

    分布式定时任务xxl-job 数据库为postgre版本

    在实际使用中,开发者需要按照XXL-JOB官方文档配置PostgreSQL数据库连接,将XXL-JOB的相关表结构导入到PostgreSQL中。同时,配置Zookeeper或Redis以实现分布式协调,确保调度中心和执行器之间的通信。在开发任务时,...

Global site tag (gtag.js) - Google Analytics