sql定時執行
A. 怎麼使某一條sql語句每天定時執行
在linux or Unix系統中有一個叫crontag的東西。
你可以設定執行的時間,它就是每天循環執行了。
格式:(second hour date month week)
00 10 * * * /u01/app/cronjob/exe_select.sh
每天十點整執行一次
B. SQL定時執行存儲過程
如果你能控制伺服器 可以在伺服器中設置計劃 執行那個程序 在程序中調用你的過程這樣是可以的
sql沒有自動執行的東西
C. SQL Server 里需要定時執行某個存儲過程,存儲過程怎麼寫
1、管理->SQL Server代理->作業(按滑鼠右鍵)->新建作業->
2、新建作業屬性(常規)->名稱[自定義本次作業的名稱]->啟用的方框內是勾號->
分類處可選擇也可用默認的[未分類(本地)]->所有者默認為登錄SQL Server用戶[也可選其它的登錄]->描述[填寫本次工作詳細描述內容];[ 創建作業分類的步驟:SQL Server代理->作業->右鍵選所有任務->添加、修改、刪除 ]
3、新建作業屬性(步驟)->新建->步驟名[自定義第一步驟名稱]->類型[Transact-SQL(TSQL)腳本]->資料庫[要操作的資料庫]->命令[ 如果是簡單的SQL直接寫進去即可,也可用打開按鈕輸入一個已寫好的*.sql文件如果要執行存儲過程,填exec p_procere_name v_parameter1,[ v_parameter2…v_parameterN]]->確定(如果有多個步驟,可以再次調用下面的新建按鈕;也可以對已有的多個步驟插入、編輯、刪除);
4、建作業屬性(調度)->新建調度->名稱[自定義調度名稱]->啟用的方框內是勾號->調度->反復出現->更改[調度時間表]->確定(如果只要保存此作業,不要定時做可以把啟用的方框內是勾號去掉);
5、建作業屬性(通知)->用默認的通知方法就好[當作業失敗時,寫入Windows應用程序系統日誌] ->確定。
D. SQL Server如何創建定時作業
我們使用SQL Server管理數據的時候,經常會在某個時間執行一些數據作業。那麼如何在SQL Server中設置定時作業呢?下面我給大家分享一下。
工具/材料
SQL Server Managment
- 01
首先打開SQL Server Managment管理軟體,展開SQL Server代理,然後右鍵單擊作業,選擇新建作業,如下圖所示
- 02
接下來會彈出新建作業界面,我們需要在在常規頁中設置定時作業的名稱和說明,如下圖所示
- 03
然後點擊步驟選項卡,在右側點擊新建按鈕,如下圖所示
- 04
接下來在新建步驟頁面中輸入要執行的定時任務名稱,一般是存儲過程或者函數的名稱,如下圖所示
- 05
點擊確定以後定時任務就添加到作業步驟列表了,如下圖所示,如果需要的話還可以添加其他的作業
- 06
接下來點擊計劃選項卡,點擊右側的新建計劃按鈕,如下圖所示
- 07
在新建計劃作業界面中選擇定時作業執行的時間間隔,這里可以靈活的設置,如下圖所示
- 08
當計劃作業設置完畢,點擊確定以後,計劃步驟就加入到了計劃列表中了,如下圖所示
- 09
最後設置完了我們回到作業文件夾下面,你就會看到剛才新建的定時任務已經添加好了,如下圖所示
E. oracle觸發器中定時執行sql
1.
關於Oracle
觸發器中定時執行SQL
的問題,
Oracle觸
發器只是在表中數據被更新
如Insert,update,delete
等情況下才會觸發,不能做到定時,只是能是有變化時才會執行!
2.
要做到定時執行可使用Job
來完成
3.
數據已經完成插入,建議插入數據時,直接使用觸發器
4.
例2:限制對Departments表修改(包括INSERT,DELETE,UPDATE)的時間范圍,即不允許在非工作時間修改departments表。
CREATE OR REPLACE TRIGGER tr_dept_time
BEFORE INSERT OR DELETE OR UPDATE
ON departments
BEGIN
IF (TO_CHAR(sysdate,'DAY') IN ('星期六', '星期日')) OR (TO_CHAR(sysdate, 'HH24:MI') NOT BETWEEN '08:30' AND '18:00') THEN
RAISE_APPLICATION_ERROR(-20001, '不是上班時間,不能修改departments表');
END IF;
END;
F. Oracle中如何定時執行一條SQL語句
通過網上查詢,找到一種方案,就是先在oracle裡面對要定時的sql寫成存儲過程,再用DBMS_scheler對存儲過程進行定時執行。
在資料庫中新建了一個表MY_JOB_TEST
在資料庫中新建了一個表MY_JOB_TEST
在資料庫中新建了一個表MY_JOB_TEST
在PLSQL中,執行下面語句模擬存儲過程的調用,執行後要點提交才有反應
[sql] view plain
BEGIN
INSERTINTOMY_JOB_TEST(NUM)VALUES(1);
END;
GrantCreateJobTo指定用戶名
SQL>CREATEORREPLACEPROCEDURE
JOB_TEST
BEGIN
INSERTINTOMY_JOB_TEST(NUM)VALUES(1);
END;
- (此處要執行存儲過程不能用exec JB_TEST,這種執行方式只能在命令行中使用)
SQL>BEGIN
DBMS_SCHEDULER.CREATE_JOB(
job_name=>'SCHEDULER_TEST',
job_type=>'STORED_PROCEDURE',
job_action=>'JOB_TEST',
start_date=>sysdate,
repeat_interval=>'FREQ=MINUTELY;INTERVAL=1');
END;
- 但是這樣子定時任務並不會執行。
SQL>SELECT*FROMUSER_SCHEDULER_JOBS;
- 此時我們可以看到enable的狀態是false的,因此我們需要去啟動定時任務
SQL>BEGIN
DBMS_SCHEDULER.ENABLE('SCHEDULER_TEST');
然後下面建立一個存儲過程JOB_TEST
(注意,這里用戶需要CREATE JOB許可權,可以用超級管理員用戶執行下面語句給指定用戶賦予該許可權)
[sql] view plain
[sql] view plain
使用DBMS_SCHEDULER進行定時,這里為每分鍾執行一次
[sql] view plain
我們可以用下面的命令查看一下scheler的狀態
[plain] view plain
[plain] view plain
dbms_scheler.enable('j_test'); --啟用jobs
dbms_scheler.disable('j_test'); --禁用jobs
dbms_scheler.run_job('j_test'); --執行jobs
dbms_scheler.stop_job('j_test'); --停止jobs
dbms_scheler.drop_job('j_test'); --刪除jobs
然後再查詢job的enable裝態,發現為true了。
然後查看MY_JOB_TEST表,發現每分鍾會往裡面添加記錄。
當需要修改定時任務或者調度的其他屬性時,可以用下面的
dbms_scheler.set_attribute('調度名','調度屬性','調度值');
至此,定時任務完成。
G. 如何將一條sql語句每天定時的執行,執行完了,自動發出簡訊
1 使用sql的job來實現sql的定時執行
2 執行完時,將簡訊信息寫入一張有關的信息表。
3 另外一個簡訊服務程序,不停查找待發簡訊,並發送
H. 怎麼樣才能讓sql資料庫定期執行一句sql語句
create or replace procere MYPROCEDURE is
begin
UPDATE mac_vod SET vod_play_url= replace(vod_play_url, '第', '弟');
commit;
end MYPROCEDURE;
declare myjob number;
begin
DBMS_JOB.SUBMIT(
job => myjob,
what => 'myprocere;',
next_date => SYSDATE,
interval => 'sysdate+5/(24*60)');
commit;
end;
I. 請教,如何定時自動執行SQL
--"類型"中選擇"Transact-SQL 腳本(TSQL)" --"資料庫"選擇執行命令的資料庫 --"命令"中輸入要執行的語句: Update City Set IsAccess=0--確定--"調度"項--新建調度--"名稱"中輸入調度名稱 --"調度類型"中選擇你的作業執行安排--定為每天調度一次,時間為18:40即可 --如果選擇"反復出現" --點"更改"來設置你的時間安排 然後將SQL Agent服務啟動,並設置為自動啟動,否則你的作業不會被執行設置方法:我的電腦--控制面板--管理工具--服務--右鍵 SQLSERVERAGENT--屬性--啟動類型--選擇"自動啟動"--確定.