夢幻之旅
DEBUG - 天道酬勤
::
首頁
::
新隨筆
::
聯系
::
聚合
::
管理
::
671 隨筆 :: 6 文章 :: 256 評論 :: 0 Trackbacks
<
2008年4月
>
日
一
二
三
四
五
六
30
31
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
1
2
3
4
5
6
7
8
9
10
公告
本博客中未注原創的文章均為轉載,對轉載內容可能做了些修改和增加圖片注釋,如果侵犯了您的版權,或沒有注明原作者,請諒解
常用鏈接
我的隨筆
我的評論
我的參與
最新評論
留言簿
(21)
給我留言
查看公開留言
查看私人留言
隨筆分類
(644)
Android(10)
(rss)
ANT(4)
(rss)
C#(10)
(rss)
C/C++(16)
(rss)
CSS(3)
(rss)
DataBase(119)
(rss)
DB-DailyMmaintenance(16)
(rss)
Design Patterns(27)
(rss)
english
(rss)
Exceptions(7)
(rss)
EXT(39)
(rss)
FLASH(9)
(rss)
Hardware(20)
(rss)
Hibernate(13)
(rss)
Html(23)
(rss)
Java(143)
(rss)
java Net(10)
(rss)
JavaScript(39)
(rss)
Linux(26)
(rss)
php(5)
(rss)
Regular Exp(3)
(rss)
Spring(17)
(rss)
Struts(12)
(rss)
TOOL(43)
(rss)
VB/VBA/VBS(5)
(rss)
webservice(9)
(rss)
XML(2)
(rss)
我的夢幻旅途(14)
(rss)
隨筆檔案
(669)
2017年9月 (4)
2016年10月 (1)
2015年6月 (1)
2015年4月 (2)
2015年1月 (1)
2014年8月 (2)
2014年7月 (9)
2014年6月 (1)
2014年5月 (2)
2014年4月 (3)
2014年3月 (3)
2013年10月 (4)
2013年9月 (8)
2013年8月 (4)
2013年6月 (3)
2013年5月 (4)
2013年4月 (7)
2013年3月 (1)
2013年1月 (3)
2012年12月 (4)
2012年11月 (1)
2012年10月 (1)
2012年9月 (4)
2012年8月 (1)
2012年7月 (2)
2012年6月 (1)
2012年5月 (4)
2012年4月 (2)
2012年3月 (1)
2012年2月 (4)
2012年1月 (6)
2011年12月 (10)
2011年11月 (7)
2011年10月 (6)
2011年9月 (37)
2011年8月 (34)
2011年7月 (44)
2011年6月 (10)
2011年5月 (5)
2011年4月 (3)
2011年3月 (1)
2011年2月 (1)
2011年1月 (18)
2010年12月 (9)
2010年11月 (13)
2010年10月 (17)
2010年9月 (2)
2010年8月 (10)
2010年7月 (10)
2010年6月 (5)
2010年5月 (8)
2010年4月 (9)
2010年3月 (11)
2010年2月 (3)
2010年1月 (8)
2009年12月 (6)
2009年11月 (10)
2009年10月 (5)
2009年9月 (1)
2009年8月 (18)
2009年7月 (6)
2009年6月 (2)
2009年5月 (1)
2009年4月 (4)
2009年3月 (6)
2009年2月 (5)
2009年1月 (3)
2008年12月 (13)
2008年11月 (13)
2008年10月 (30)
2008年9月 (9)
2008年8月 (24)
2008年7月 (17)
2008年6月 (15)
2008年5月 (16)
2008年4月 (15)
2008年3月 (19)
2008年2月 (3)
2008年1月 (20)
2007年12月 (24)
2007年11月 (9)
文章檔案
(6)
2008年4月 (1)
2008年3月 (1)
2008年1月 (2)
2007年11月 (2)
最新隨筆
1.?PP代碼生成器(四) 使用解決方案生成代碼
2.? PP代碼生成器(三) 設計freemarker模板, 創建解決方案
3.? PP代碼生成器(二) 解決方案, 生成任務, 輔助設計面板
4.? PP代碼生成器(一) 簡介, 下載, 運行
5.?PP持久層代碼生成器
6.?比較好的博客
7.?系統集成項目管理工程師
8.?軟件公司項目經理崗位職責
9.?聯想筆記本 顯示屏 鍵盤失靈 釋放靜電
10.?eclipse maven
積分與排名
積分 - 963991
排名 - 36
最新評論
1.?re: Myeclipse 快捷鍵大全(絕對全)
crl+向右箭頭(輸入法有問題打不出來)移到下一個參數的位置,然后crl+shift+向右箭頭 選中該位置的參數即可
--紅領巾
2.?re: Log4j基本使用方法
555
--555
3.?re: Myeclipse 快捷鍵大全(絕對全)[未登錄]
很不錯,謝謝
--銀狐
4.?re: Flex 表單
是誰這么無聊~嗚~~~
--HUIKK
5.?re: Spring AfterReturning 異常
具體是什么意思啊
--dingli
閱讀排行榜
1.?Exception in thread "main" java.lang.NoClassDefFoundError: com/sun/mail/util/LineInputStream(70038)
2.?log4j.properties 使用說明(42093)
3.?Myeclipse 快捷鍵大全(絕對全)(32743)
4.?TNSNAMES.ORA 配置(24405)
5.?oracle 樹狀查詢(21371)
評論排行榜
1.?Exception in thread "main" java.lang.NoClassDefFoundError: com/sun/mail/util/LineInputStream(53)
2.?JMail 異常: java.lang.NoClassDefFoundError: javax/activation/DataSource(21)
3.?javax.mail.MessagingException: 530 5.7.0 Must issue a STARTTLS command first(14)
4.?java 讀取 excel 2003 或 excel 2007(14)
5.?java.lang.UnsupportedClassVersionError: Bad version number in .class file(8)
Oracle 定時任務 JOB
眾所周知,一般操作系統會提供定時執行任務的方法,例如:Unix平臺上提供了讓系統定時執行任務的命令Crontab。但是,對于某些需求,例如:一些對數據庫表的操作,最為典型的是證券交易所每日收盤后的結算,它涉及大量的數據庫表操作,如果仍然利用操作系統去定時執行,不僅需要大量的編程工作,而且還會出現用戶不一致等運行錯誤,甚至導致程序無法執行。
一、分析問題
事實上,對于以上需求,我們可以利用數據庫本身擁有的功能Job Queue(任務隊列管理器)去實現。任務隊列管理器允許用戶提前調度和安排某一任務,使其能在指定的時間點或時間段內自動執行一次或多次,由于任務在數據庫中被執行,所以執行效率很高。
任務隊列管理器允許我們定制任務的執行時間,并提供了靈活的處理方式,還可以通過配置,安排任務在系統用戶訪問量少的時段內執行,極大地提高了工作效率。例如,對于數據庫日常的備份、更新、刪除和復制等耗時長、重復性強的工作,我們就可以利用任務隊列管理器去自動執行以減少工作量。
目前,擁有此項功能的數據庫有許多,最有代表性的是SQL Server 7.0、Oracle 8.0.5等。但是,要讓任務隊列管理器工作,還需要我們加以配置才能實現。SQL Server的功能配置是在一個圖形化界面(GUI)中實現的,非常簡單。利用OEM客戶端管理工具,Oracle的配置也可以在一個圖形界面中完成。然而大多數的用戶更習慣于命令行的方式去操縱數據庫。本文介紹如何通過命令行實現這種配置。
二、實現步驟
1.確保Oracle的工作模式允許啟動任務隊列管理器
Oracle定時執行“Job Queue”的后臺程序是SNP進程,而要啟動SNP進程,首先要確保整個系統的模式是可以啟動SNP進程的,這需要以DBA的身份去執行如下命令:
svrmgrl> alter system enable restricted session;
或sql> alter system disenable restricted session;
利用如上命令更改系統的會話方式為disenable restricted,為SNP的啟動創造條件。
2.確保Oracle的系統已經配置了任務隊列管理器的啟動參數
SNP的啟動參數位于Oracle的初始化文件中,該文件放在$ORACLE_HOME/dbs路徑下,如果Oracle的SID是myora8的話,則初始化文件就是initmyora8.ora,在文件中對SNP啟動參數的描述部分如下:
job_queue_process=n
job_queue_interval=N
第一行定義SNP進程的啟動個數為n。系統缺省值為0,正常定義范圍為0~36,根據任務的多少,可以配置不同的數值。
第二行定義系統每隔N秒喚醒該進程一次。系統缺省值為60秒,正常范圍為1~3600秒。事實上,該進程執行完當前任務后,就進入睡眠狀態,睡眠一段時間后,由系統的總控負責將其喚醒。
如果該文件中沒有上面兩行,請按照如上配置添加。配置完成后,需要重新啟動數據庫,使其生效。注意:如果任務要求執行的間隔很短的話,N的配置也要相應地小一點。
3.將任務加入到數據庫的任務隊列中
調用Oracle的dbms_job包中的存儲過程,將任務加入到任務隊列中:
dbms_job.submit( job out binary_integer,
what in archar2,
next_date in date,
interval in varchar2,
no_parse in boolean)
其中:
●job:輸出變量,是此任務在任務隊列中的編號;
●what:執行的任務的名稱及其輸入參數;
●next_date:任務執行的時間;
●interval:任務執行的時間間隔。
下面詳細討論一下dbms_job.submit中的參數interval。嚴格地講,interval是指上一次執行結束到下一次開始執行的時間間隔,當interval設置為null時,該job執行結束后,就被從隊列中刪除。假如我們需要該job周期性地執行,則要用‘sysdate+m’表示。
將任務加入到任務隊列之前,要確定執行任務的數據庫用戶,若用戶是scott, 則需要確保該用戶擁有執行包dbms_job的權限;若沒有,需要以DBA的身份將權利授予scott用戶:
svrmgrl> grant execute on dbms_job to scott;
4.將要執行的任務寫成存儲過程或其他的數據庫可執行的pl/sql程序段
例如,我們已經建立了一個存儲過程,其名稱為my_job,在sql/plus中以scott用戶身份登錄,執行如下命令:
sql> variable n number;
sql> begin
dbms_job.submit(:n‘my_job;’,sysdate,
‘sysdate+1/360’);
commit;
end;
/
系統提示執行成功。
Sql> print :n;
系統打印此任務的編號,例如結果為300。
如上,我們創建了一個每隔4分鐘執行一次的任務號為300的任務。可以通過Oracle提供的數據字典user_jobs察看該任務的執行情況:
sql> select job,next_date,next_sec,failures,broken from user_jobs;
執行結果如下:
job next_date next_sec failures broken
300 2000/10/10 11:45:15 0 N
這表示任務號為300的任務,下一次將在2000/10/10 11:45:15執行,此任務的執行失敗記錄為0次。注意:當執行job出現錯誤時,Oracle將其記錄在日志里,失敗次數每次自動加1。當執行失敗次數達到16時,Oracle就將該job標志為broken。此后,Oracle不再繼續執行它,直到用戶調用過程dbms_job.broken,重新設置為not broken,或強制調用dbms_job.run來重新執行它。
除了以上我們討論的submit存儲過程之外,Oracle還提供了其他許多存儲過程來操作任務。例如:dbms_job.change 、 dbms_job.what、dbms_job.interval可以用來修改提交的任務。要想刪除該任務,只需運行dbms_job.remove(n)即可,其中n為任務號。
posted on 2008-04-02 17:00
HUIKK
閱讀(452)
評論(0)
編輯
收藏
所屬分類:
DataBase
新用戶注冊
刷新評論列表
只有注冊用戶
登錄
后才能發表評論。
網站導航:
博客園
IT新聞
Chat2DB
C++博客
博問
管理
相關文章:
Oracle Data Guard Linux 平臺 Physical Standby 搭建實例()
oracle 批量更新
PL/SQL中SELECT INTO無記錄的情況
windows環境下Oracle數據庫冷備份和恢復全過程
oracle10g數據庫冷備份、恢復的具體步驟(轉)
oracle 正則 匹配中文
PowerDesigner設置
SQLPLUS SPOOL命令使用
Oracle執行SQL時遭遇特殊字符&
oracle及操作系統對于文件大小的限制
Powered by:
BlogJava
Copyright © HUIKK
主站蜘蛛池模板:
欧洲一级毛片免费
|
yy一级毛片免费视频
|
亚洲国产精品自在线一区二区
|
亚洲精品国产日韩无码AV永久免费网
|
亚洲最大AV网站在线观看
|
2022年亚洲午夜一区二区福利
|
久久综合久久综合亚洲
|
亚洲国产精品无码中文lv
|
精品免费久久久久国产一区
|
91青青青国产在观免费影视
|
四虎永久成人免费影院域名
|
成人午夜亚洲精品无码网站
|
婷婷亚洲综合五月天小说
|
亚洲三级高清免费
|
最近最新的免费中文字幕
|
亚洲人成无码网WWW
|
亚洲国产精品白丝在线观看
|
污视频网站免费观看
|
一区二区三区福利视频免费观看
|
在线免费观看一级片
|
亚洲视频精品在线
|
亚洲毛片免费观看
|
国产亚洲精品美女久久久
|
久久亚洲AV成人无码国产电影
|
亚洲av无一区二区三区
|
国产精品极品美女免费观看
|
亚洲无成人网77777
|
全免费a级毛片免费**视频
|
久久久久久久亚洲Av无码
|
CAOPORN国产精品免费视频
|
亚洲欧洲国产精品香蕉网
|
免费看又黄又爽又猛的视频软件
|
国产精品亚洲mnbav网站
|
亚洲av中文无码
|
在线亚洲高清揄拍自拍一品区
|
少妇亚洲免费精品
|
狠狠久久永久免费观看
|
精品多毛少妇人妻AV免费久久
|
亚洲视频免费在线看
|
免费观看日本污污ww网站一区
|
免费一区二区无码东京热
|