job執行存儲過程
Ⅰ oracle job執行存儲過程問題。
把你的存儲過程重新編譯一遍
Ⅱ 如何在存儲過程/sql語句執行job(作業)
用以下語句是可以執行的
(如果Job名稱是 Job_A)
EXEC msdb.dbo.sp_start_job N'Job_A'
注:最好用Try Catch捕捉到錯誤,因為如果要啟動的Job_A不存在的話會報錯
如果確定Job名存在的話那就不會有問題
Ⅲ oracle資料庫job怎麼調用含參數的存儲過程
dbms_job.submit(test_job_really,'test_jobproce("zhangsan");',sysdate,'sysdate+1/1440');
改為:
dbms_job.submit(test_job_really,'test_jobproce(''zhangsan'');',sysdate,'sysdate+1/1440');
注意:zhangsan的兩邊,不是雙引號,是兩個單引號!
如有幫助,請採納!
Ⅳ 是不是一個JOB只能定時執行一個存儲過程
定時執行存儲過程,需要在job里定義;而執行多個存儲過程,則在job中定義多次即可。
運行環境:oracle 10g
1、定義其中一個job
1
2
3
4
5
6
7
8
9
10
11
12
13
declare
jobno number;
begin
dbms_job.submit(11,
what => 'pro_bdc_bh(
to_char(add_months(trunc(sysdate),-1),''yyyy''),
to_char(add_months(trunc(sysdate),-1),''MM''),
''true''
);',
next_date => sysdate,
Interval => 'TRUNC(sysdate) + 1 +2 / (24)');
commit;
end;
注意:其中pro_bdc_bh為存儲過程名稱,TRUNC(sysdate) + 1 +2 / (24)為定義的運行時間為每日凌晨2點。
2、然後定義另外一個job
1
2
3
4
5
6
7
8
9
10
11
12
13
declare
jobno number;
begin
dbms_job.submit(11,
what => 'p_test(
to_char(add_months(trunc(sysdate),-1),''yyyy''),
to_char(add_months(trunc(sysdate),-1),''MM''),
''true''
);',
next_date => sysdate,
Ⅳ 存儲過程單獨執行沒問題,加到job裡面就報錯
本來存儲過程不加Authid Current_User會提示許可權不足,然後會出現序列刪除成功,但是無法新建的奇怪現象。
加了以後一切正常,但是放在job裡面執行後,又出這個問題了,序列刪了,但是沒有新建。
Ⅵ 各位大蝦,job定時問題:job定時執行存儲過程,想整點執行,怎麼實現啊,
如果是10g的話就用scheler來代替job吧,比job穩定多了。
先解釋一下基礎概念,scheler 包含了以下幾個實體對象
Program -- 提供了scheler 將要運行什麼,包含program name,program type(PLSQL塊、存儲過程、外部程序),program action(具體的程序實體,比如說一個PLSQL塊、或者是存儲過程的名稱、或者是外部程序的路徑加名稱) 。
Scheles -- 指定何時何種頻率來運行job,可以被不同的job重復的利用。比如說我有兩個job都要求在每天的凌晨4點運行,那麼兩個job可以同時指定相同的schele。
Jobs -- 具體的作業的名稱,依賴於那個program、schele。也可以不指定program、schele,而直接寫入program、schele的相應參數。
Chains -- 把一組program像一個單獨的實體連接在一起,作為一個對象。Job可以指向Chains代替單一的program 。這樣就能完成類似如下功能:運行A,然後運行B,當A、B都運行成功則運行C,否則運行D。
下面參考文檔邊看邊做。
1.創建一張表 create table scheler_test(id number,instime date);
2.創建一個存儲過程,實現往表中插入資料。
create or replace procere p_insSysdate as
id number;
begin
select count(*) into id from scheler_test;
insert into scheler_test values(id,sysdate);
commit;
end;
/
3.創建一個schele,這個僅僅是一個時間上的安排,由DBMS_SCHEDULER.CREATE_JOB調用。這樣就可以重用schele,並且schele在時間的安排上強大與原先的JOB 。語法如下:
BEGIN
SYS.DBMS_SCHEDULER.CREATE_SCHEDULE
(
schele_name => 'SCOTT.EVERY_MINUTE'
,start_date => NULL
,repeat_interval => 'FREQ=MINUTELY'
,end_date => NULL
,comments => NULL
);
END;
/
以下給出部分repeat_interval的寫法實例,以供參考
EVERY DAY 'FREQ=DAILY;INTERVAL=1'
EVERY MINUTE 'FREQ=MINUTELY;INTERVAL=1'
EVERY 4 HOURS ON THE HOUR 'FREQ=HOURLY;INTERVAL=4;BYMINUTE=0;BYSECOND=0'
1st DAY OF EVERY MONTH 'FREQ=DAILY;BYMONTHDAY=1'
WEEKDAYS AT 7am and 3pm 'FREQ=DAILY; BYDAY=MON,TUE,WED,THU,FRI; BYHOUR=7,15; BYMINUTE=0;BYSECOND=0'
4.創建DBMS_SCHEDULER.CREATE_PROGRAM,指定運行什麼樣的程序。
BEGIN
SYS.DBMS_SCHEDULER.CREATE_PROGRAM
(
program_name => 'SCOTT.PRG_INSSYSDATE'
,program_type => 'STORED_PROCEDURE'
,program_action => 'p_insSysdate'
,number_of_arguments => 0
,enabled => TRUE
,comments => NULL
);
END;
/
Ⅶ oracle job 執行帶參數的存儲過程;每天定時將A表新產生的數據定期更新到B表中,存儲過程有一個時間參數
execute P_JBXX_NSZHDJXXB_NEW(TO_CHAR(SYSDATE,'yyyy-mm-dd hh24:mi:ss'))
Ⅷ 如何寫SQLServer的JOB讓它每天定時的執行某個存儲過程
create proc p_createjob
@jobname varchar(100), --作業名稱
@sql varchar(8000), --要執行的命令
@serverName sysname='', --job server名
@dbname sysname='', --默認為當前的資料庫名
@freqtype varchar(6)='day', --時間周期,month 月,week 周,day 日
@fsinterval int=1, --相對於每日的重復次數
@time int=170000 --開始執行時間,對於重復執行的作業,將從0點到23:59分!
Ⅸ 定時執行帶參數的存儲過程,怎麼定義job
/*
查詢:
selectjob,broken,what,interval,t.*fromuser_jobst;
jobjob的唯一標識,自動生成的
broken是否處於運行狀態,N;運行;Y:停止
what存儲過程名稱
next_date初次執行時間
interval執行周期
刪除:
begindbms_job.remove(jobno);end;
根據what的內容確定其對應的job,並如此執行刪除
執行時間例子:
描述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)''
每3秒鍾執行一次'sysdate+3/(24*60*60)'
每2分鍾執行一次'sysdate+2/(24*60)'
1:每分鍾執行
Interval=>TRUNC(sysdate,'mi')+1/(24*60)--每分鍾執行
interval=>'sysdate+1/(24*60)'--每分鍾執行
interval=>'sysdate+1'--每天
interval=>'sysdate+1/24'--每小時
interval=>'sysdate+2/24*60'--每2分鍾
interval=>'sysdate+30/24*60*60'--每30秒
2:每天定時執行
Interval=>TRUNC(sysdate+1)--每天凌晨0點執行
Interval=>TRUNC(sysdate+1)+1/24--每天凌晨1點執行
Interval=>TRUNC(SYSDATE+1)+(8*60+30)/(24*60)--每天早上8點30分執行
3:每周定時執行
Interval=>TRUNC(next_day(sysdate,'星期一'))+1/24--每周一凌晨1點執行
Interval=>TRUNC(next_day(sysdate,1))+2/24--每周一凌晨2點執行
4:每月定時執行
Interval=>TTRUNC(LAST_DAY(SYSDATE)+1)--每月1日凌晨0點執行
Interval=>TRUNC(LAST_DAY(SYSDATE))+1+1/24--每月1日凌晨1點執行
5:每季度定時執行
Interval=>TRUNC(ADD_MONTHS(SYSDATE,3),'q')--每季度的第一天凌晨0點執行
Interval=>TRUNC(ADD_MONTHS(SYSDATE,3),'q')+1/24--每季度的第一天凌晨1點執行
Interval=>TRUNC(ADD_MONTHS(SYSDATE+2/24,3),'q')-1/24--每季度的最後一天的晚上11點執行
6:每半年定時執行
Interval=>ADD_MONTHS(trunc(sysdate,'yyyy'),6)+1/24--每年7月1日和1月1日凌晨1點
7:每年定時執行
Interval=>ADD_MONTHS(trunc(sysdate,'yyyy'),12)+1/24--每年1月1日凌晨1點執行
相關方法:
修改要執行的操作:dbms_job.what(jobno,'sp_fact_charge_code;');--修改某個job名
修改下次執行時間:dbms_job.next_date(job,next_date);
修改間隔時間:dbms_job.interval(job,interval);
停止job:dbms.broken(job,broken,nextdate);
dbms_job.broken(v_job,true,next_date);--停止一個job,裡面參數true也可是false,next_date(某一時刻停止)也可是sysdate(立刻停止)。
*/
createorreplaceprocereproc_auto_exec_jobas
begin
declare
jobnumber;
BEGIN
DBMS_JOB.SUBMIT(
JOB=>job,/*自動生成JOB_ID*/
WHAT=>'proc_test_job;',/*需要執行的過程或SQL語句*/
/*NEXT_DATE=>sysdate,*//*初次執行時間,立刻執行*/
/*INTERVAL=>'sysdate+3/(24*60*60)'*//*執行周期-每3秒鍾*/
NEXT_DATE=>TRUNC(SYSDATE+1)+(0*60+30)/(24*60), /*初次執行時間,12點30分*/
INTERVAL=>'TRUNC(SYSDATE+1)+(0*60+30)/(24*60)' /*每天12點30分*/
);
COMMIT;
/*dbms_job.submit(job,'proc_test_job;',sysdate,'trunc(sysdate,''mi'')+1/(24*60)');/*執行周期-每1分鍾*/
commit;*/
DBMS_JOB.RUN(job);
end;
endproc_auto_exec_job;
beginproc_auto_exec_job;end;
ORACLE 定時執行存儲過程