溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

存儲(chǔ)過程+job 定時(shí)執(zhí)行固定的SQL語句

發(fā)布時(shí)間:2020-08-06 22:45:40 來源:ITPUB博客 閱讀:126 作者:一只安靜的DBA 欄目:關(guān)系型數(shù)據(jù)庫

做報(bào)表時(shí),需要讀取大量數(shù)據(jù)和進(jìn)行復(fù)雜的計(jì)算,往往比較耗時(shí),所以一般會(huì)將結(jié)果存放在一張結(jié)果表中,報(bào)表直接讀取結(jié)果表,這樣就會(huì)很快了。此時(shí),為了更新結(jié)果表,獲得最新數(shù)據(jù),就需要定時(shí)執(zhí)行一些SQL語句,此時(shí)可以采用:存儲(chǔ)過程+job的方式來達(dá)到目的,具體步驟如下
創(chuàng)建存儲(chǔ)過程:

create or replace procedure datawarn.P_TEST is

begin

  delete from test_table;
  insert test_table select * from table1;          --sql塊,即你要執(zhí)行的sql語句

  commit; --sql塊

end;


執(zhí)行存儲(chǔ)過程(手動(dòng)調(diào)用一次存儲(chǔ)過程):

EXEC 存儲(chǔ)過程名;



創(chuàng)建JOB:

begin

dbms_scheduler.create_job (

job_name => 'J_TEST', --JOB名稱

job_type => 'STORED_PROCEDURE',

job_action => 'P_TEST', --存儲(chǔ)過程名

start_date => sysdate,

repeat_interval => 'FREQ=MINUTELY; INTERVAL=10', -- 十分鐘一次

comments => 'JOB說明'

);

end;

ps:創(chuàng)建job的時(shí)候要小心一點(diǎn),仔細(xì)檢查,不要寫錯(cuò)信息,如果報(bào)錯(cuò),再次創(chuàng)建會(huì)導(dǎo)致創(chuàng)建不成功,可以換個(gè)job名稱嘗試一下 

--啟動(dòng)

begin

dbms_scheduler.enable('J_TEST');

end;


執(zhí)行

begin

dbms_scheduler.run_job(job_name => 'J_TEST',force => TRUE); -- true代表同步執(zhí)行

end;

停止

dbms_scheduler.stop_job(job_name => 'J_TEST',force => TRUE);

--DI JOB查詢

select * from tsc_jobstatus

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI