orcl创建定时任务,定时新增,删除数据

1.创建任务执行的存储过程,如名称为 TEST_JOB,向测试表中插入数据
create or replace procedure TEST_JOB is
begin
  insert into  T_TABLE values('test',sysdate);
end;
2.创建定时任务
declare  
   TEST_JOB_NAME number;  
 begin  
   sys.dbms_job.submit(TEST_JOB_NAME, --任务名称  
                       'TEST_JOB',--执行的过程  存储过程,多个可以,隔开
                       sysdate,--第一次执行时间  
                       'TRUNC(sysdate+ 1)  +7/ (24)');--下次执行时间  
  COMMIT;
end;
3.查看任务
select * from  dba_jobs 
注:注意,如果next_date是4000-1-1表示这个脚本已经是停止状态

注:

其它应用
1.执行任务
 begin  
 dbms_job.run(25);--25为任务的id  
 end;   
 
2.停止任务
 begin
  dbms_job.broken(25, true, sysdate);
  commit;
 end;
 
3.删除任务
 begin  
 dbms_job.remove(25);  
 end;   
job的定时执行和时间间隔说明
间隔/interval是指上一次执行结束到下一次开始执行的时间间隔,当interval设置为null时,
该job执行结束后,就被从队列中删除。假如我们需要该job周期性地执行,则要用‘sysdate+m’表示。
(1).每分钟执行
Interval => TRUNC(sysdate,'mi') + 1/ (24*60)

每小时执行

Interval => TRUNC(sysdate,'hh') + 1/ (24)

(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

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、提供了oracle数据库备份脚本,导出dmp文件 2、定时任务由操作系统提供的支持,在操作系统中设置定时任务,由操作系统定期执行脚本 3、补充。压缩包脚本有点问题,不能删除旧的备份文件。需要自动删除历史备份文件请用最新脚本: @echo off @echo ================================================ @echo windows环境下Oracle数据库的自动备份脚本 @echo 说明:启动备份时,需要配置以下变量 @echo 1、BACKUP_DIR 指定要备份到哪个目录 @echo 2、ORACLE_USERNAME 指定备份所用的Oracle用户名 @echo 3、ORACLE_PASSWORD 指定备份所用的Oracle密码 @echo 4、ORACLE_DB 指定备份所用的Oracle连接名 @echo 5、BACK_OPTION 备份选项,可以为空,可以为full=y,可以为owner=a用户,b用户 等等.... @echo 6、RAR_CMD 指定RAR命令行压缩工具所在目录 @echo ================================================ rem 以下变量需要根据实际情况配置 set BACKUP_DIR=D:\tools\oracle_bak\backup230 set ORACLE_USERNAME=PLATADMIN set ORACLE_PASSWORD=123456 set ORACLE_DB=ORCL set BACK_OPTION=owner=PLATADMIN set RAR_CMD="D:/Program Files/WinRAR/Rar.exe" rem for /f "tokens=1,2" %%a in ('date/t') do set TODAY=%%a rem set BACK_NAME=%ORACLE_DB%_%TODAY%(%time:~0,2%时%time:~3,2%分)_ set BACK_NAME=%Date:~0,4%%Date:~5,2%%Date:~8,2%%Time:~0,2%%Time:~3,2%%Time:~6,2% set BACK_FULL_NAME=%BACKUP_DIR%/%BACK_NAME% rem 开始备份 exp %ORACLE_USERNAME%/%ORACLE_PASSWORD%@%ORACLE_DB% %BACK_OPTION% file="%BACK_FULL_NAME%.dmp" log="%BACK_FULL_NAME%exp.log" rem 压缩并删除原有文件 %RAR_CMD% a -df "%BACK_FULL_NAME%back.rar" "%BACK_FULL_NAME%.dmp" "%BACK_FULL_NAME%exp.log" rem 删除15天前的备份文件 forfiles /p %BACKUP_DIR% /s /m *.rar /d -15 /c "cmd /c del @file"
要实现定时迁移Oracle数据到达梦数据库,可以使用PHP编写一个脚本来完成。下面是一个简单的示例: ```php <?php //设置Oracle数据库连接信息 $oracleHost = 'localhost'; $oraclePort = '1521'; $oracleSID = 'ORCL'; $oracleUser = 'username'; $oraclePass = 'password'; //设置达梦数据库连接信息 $damaHost = 'localhost'; $damaPort = '5236'; $damaDbname = 'databasename'; $damaUser = 'username'; $damaPass = 'password'; //创建Oracle数据库连接 $oracleConn = oci_connect($oracleUser, $oraclePass, "(DESCRIPTION=(ADDRESS=(PROTOCOL=TCP)(HOST=$oracleHost)(PORT=$oraclePort))(CONNECT_DATA=(SID=$oracleSID)))"); if (!$oracleConn) { $e = oci_error(); trigger_error(htmlentities($e['message'], ENT_QUOTES), E_USER_ERROR); } //创建达梦数据库连接 $damaConn = new PDO("dm:host=$damaHost;port=$damaPort;dbname=$damaDbname", $damaUser, $damaPass); //查询Oracle数据 $query = 'SELECT * FROM oracle_table'; $oracleStmt = oci_parse($oracleConn, $query); oci_execute($oracleStmt); //插入到达梦数据库 while ($row = oci_fetch_array($oracleStmt, OCI_ASSOC)) { $damaStmt = $damaConn->prepare('INSERT INTO dama_table (col1, col2) VALUES (:col1, :col2)'); $damaStmt->bindParam(':col1', $row['COL1']); $damaStmt->bindParam(':col2', $row['COL2']); $damaStmt->execute(); } //关闭Oracle和达梦数据库连接 oci_free_statement($oracleStmt); oci_close($oracleConn); $damaConn = null; ``` 以上是一个简单的示例,你可以根据需要进行修改。同时,你还需要在服务器上设置一个定时任务来定期运行这个脚本。可以使用Linux的Cron来实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值