原帖由 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)。
分享到:
相关推荐
当我们需要将本地文件导入数据库时,通常会遵循一定的步骤以确保数据的完整性和安全性。本篇文章将详细阐述如何将本地文件导入数据库,以及在导入后如何进行备份和删除原文件。 首先,我们来了解一下“本地文件导入...
7. **自动化流程**:为了提高效率,可以将上述过程封装为脚本或工具,实现定期自动从Excel导入数据到数据库,例如通过Windows计划任务、Linux cron job或编程语言的定时任务。 总之,将Excel数据导入数据库是一个...
- 使用PowerShell读取Excel,结合SQL Server的SMO(Server Management Objects)库,将数据导入数据库。 4. **VBA宏** - 在Excel中编写VBA代码,直接与数据库交互,将数据插入到指定的表。 三、自动化流程 1. **...
自动导入Excel程序是企业信息化中不可或缺的部分,特别是在数据密集型业务中,如数据分析、报表生成和数据库填充。熟练掌握这项技术,可以帮助IT专业人员提高工作效率,减少人为错误,并支持企业的数据驱动决策。
这是一个使用PHP编程语言编写的程序,其主要功能是自动导入数据库备份。"faisunSQL"很可能是该程序的特定名称或作者的标识。此外,"UTF-8版"强调了源码文件的字符编码格式,这意味着程序在处理文本数据时将遵循UTF-8...
总之,"Oracle 数据库自动备份工具"是确保数据安全不可或缺的一部分,它可以帮助管理员有效地管理和执行数据库备份任务,降低因数据丢失带来的风险。通过深入理解和正确使用这类工具,可以大大提高数据库管理的效率...
相比于图形界面工具(如Oracle SQL Developer或Oracle Enterprise Manager),通过命令行来进行Oracle数据库的导入导出操作不仅更为高效快捷,而且在自动化运维场景下具有更大的灵活性。本文将详细介绍如何利用`...
该压缩包文件“PHP实例开发源码-faisunSQL自导入数据库备份程序(UTF-8版).zip”是一个包含PHP源代码的项目,主要用于实现自动导入和备份数据库的功能。这个程序可能对那些需要管理和保护其数据库数据的Web开发者非常...
### 数据库的导入导出详解 #### 一、概述 在数据库管理中,数据的导入导出是一项非常重要的操作,特别是在进行数据迁移、备份恢复等场景下。本文将重点介绍Oracle数据库中的导入导出操作,主要包括表空间的创建...
这个功能对于需要定期或重复导入数据的场景非常有用,只需通过DOS命令行执行预先设定好的job脚本,就能自动化完成数据导入任务,大大提高了工作效率。 另一个显著特性是,用户可以通过SQL语句来筛选源表中的部分...
为了安全起见,这个脚本应该配置为定期任务,例如通过Windows的任务计划程序或Linux的cron job,以确保在固定的时间点自动执行。此外,为了验证备份的完整性,应定期进行恢复测试。 总的来说,`backup.bat`脚本是一...
在这个案例中,它可能是负责整个流程调度和监控的部分,确保生成数据和导入数据库的操作按照预定的时间和顺序执行。 - "生成亿级随机数据.ktr":这是Kettle的转换文件(Transformation),直接执行数据生成的任务。...
如果在执行导入操作时遇到错误ORA-31684(用户已经存在),则可能需要先删除已存在的用户再重新执行导入操作。 通过以上步骤,我们可以有效地进行Oracle数据库的还原操作,包括创建必要的表空间、用户及其权限配置...
利用crontab和shell脚本自动执行sar、iostat等命令收集数据;还使用Oracle自带的工具如v$_xxx、dba_xxx等进行数据库性能监控;并通过AWR报告对数据库的性能进行深入分析。 - **性能监控示例**: - **主机性能监控*...
为了解决这个问题,Oracle引入了DBMS_JOB包,这是一个内置的PL/SQL包,用于安排存储过程和其他PL/SQL块的自动执行。通过DBMS_JOB,DBA可以设置定时任务,让系统在特定时间自动运行备份脚本或者数据处理过程,从而...
5. **数据管理**:浏览表结构,插入、更新、删除数据,执行数据导出导入等操作。 6. **版本控制集成**:与Git等版本控制系统集成,管理PLSQL代码的版本。 7. **性能分析**:通过执行计划、调用堆栈等工具分析代码...
`--create testsqoopjob` 创建了一个名为testsqoopjob的job,`--import` 表示导入操作,接着是连接数据库的相关参数,`--target-dir` 指定了HDFS上的目标目录,`--table person` 指定了要导入的表,`--m 1` 设置了...
8. **自动化工具**:利用脚本或自动化工具(如cron job)定期执行数据库维护任务,如数据导入导出、备份恢复等。 9. **源码管理**:如果源码是用编程语言编写的,可能涉及到版本控制工具如Git,用于协同开发和版本...
在实际使用中,开发者需要按照XXL-JOB官方文档配置PostgreSQL数据库连接,将XXL-JOB的相关表结构导入到PostgreSQL中。同时,配置Zookeeper或Redis以实现分布式协调,确保调度中心和执行器之间的通信。在开发任务时,...