當前位置:首頁 » 編程語言 » php定時任務sql
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

php定時任務sql

發布時間: 2022-07-05 14:22:43

Ⅰ php如何實現定時任務,php定時任務方法,最佳

PHP製作定時任務(也稱計劃任務)的方法,大概分為2種:

  1. 現在基本所有的PHP框架,如:ThinkPHP,Yii,Laravel等等;它們都是單入口的形式,也就是說所有的請求都集合到index.php中,然後再由框架核心來根據請求參數的不同來分配到不同的控制器當中。基於單入口的形式,那麼就可以做基於行為(例如TP3.2)或者說基於事件的定時任務。

  2. 系統自動的定時任務,比如Linux的crontab,windows的計劃任務等。

兩中方法各有所長各有所短

基於事件:這種利用的是框架本身提供的一些行為來實現,優點是:不需要特殊配置,只要項目能跑起來,那麼定時任務也能執行。缺點是:靈活性比較差,必須要藉助框架實現。

基於系統:基於操作系統來實現,優點是:靈活性很高,而且可控性也很好。缺點是:需要特殊配置,專業要求性比較強。

具體要使用哪種方法,可以依據自己的能力和項目需要來選擇。最後附上TP3.2的定時任務配置,這個只需要配置就可以,如果想查看具體實現原理,可以查看/ThinkPHP/Library/Behavior/CronRunBehavior.class.php

第一步:/Application/Common/Conf目錄下新建兩個文件:
分別如:
/Application/Common/Conf/tags.php
/Application/Common/Conf/crons.php

1)新建tags.php,編輯內容如下:
returnarray(
'app_end'=>array('BehaviorCronRunBehavior'),
);

2)新建crons.php,編輯內容如下:
returnarray(
'cron_1'=>array('myplan',1),
);

第二步:/Application/目錄下新建Cron文件夾,裡面新建文件myplan.php文件
路徑如:/Application/Cron/myplan.php
編輯內容如下:
echo11111;

查看是否運行成功,最簡單的方法是查看/Application/Runtime/~crons.php,這個文件是否存在。

Ⅱ php定時執行任務怎麼寫

藉助crontab來編寫;

  1. 編寫定時執行腳本(單獨的一個php文件,或者某個方法);

  2. 配置crontab,指定執行路徑地址;

  3. 啟動crontab服務即可。

Ⅲ php怎麼做定時任務的,感謝大牛指點

寫一個你需要的php業務的腳本,然後在伺服器上,設置定時任務,執行這個腳本,就行了

Ⅳ 每天中午12點,在php中定時的執行mysql中sql語句,後者定時的執行方法也可以

ignore_user_abort(true);//無視用戶斷開,程序在伺服器繼續執行
set_time_limit(0);//程序無限執行
這個方法在iis下穩定性欠佳,其他伺服器下沒試過

Ⅳ php mysql怎麼創建可以定時執行任務的過程語句存儲過程定時執行sql

伺服器的話可以使用計劃任務。
如果是虛擬主機只能使用死循環+判定條件了。

Ⅵ php定時執行任務的幾個方法

PHP定時執行的三種方式實現
1、windows 的計劃任務 2、linux的腳本程序 3、讓web瀏覽器定時刷新

具體實現
1、windows計劃任務

PHP很少在win伺服器上跑,具體實現也不再深究,看網上實現的原理大概是寫bat腳本,然後讓window任務添加執行這個bat腳本。
2、linux 的腳本實現
這里主要使用到crontab這個命令,
使用方式 :

復制代碼 代碼如下:crontab filecrontab [ -u user ] [ -u user ] { -l | -r | -e }

說明 :

crontab是用來讓使用者在固定時間或固定間隔執行程式之用

使用crontab寫shell腳本,然後讓PHP調用shell,這個是利用linux的特性,應該還不算PHP自身語言的特性

3、PHP實現定時執行計劃任務
使用php讓瀏覽器刷新需要解決幾個問題
PHP腳本執行時間限制,默認的是30m 解決辦法:set_time_limit();或者修改PHP.ini 設置max_execution_time時間(不推薦)
如果客戶端瀏覽器關閉,程序可能就被迫終止,解決辦法:ignore_user_abort即使關閉頁面依然正常執行
如果程序一直執行很有可能會消耗大量的資源,解決辦法使用sleep使用程序休眠一會,然後在執行
PHP定時執行的代碼:

<?php ignore_user_abort();//關掉瀏覽器,PHP腳本也可以繼續執行. set_time_limit(3000);// 通過set_time_limit(0)可以讓程序無限制的執行下去 $interval=5;// 每隔5s運行 //方法1--死循環 do{ echo '測試'.time().'<br/>'; sleep($interval);// 等待5s }while(true); //方法2---sleep 定時執行 require_once './curlClass.php';//引入文件 $curl = new httpCurl();//實例化 $stime = $curl->getmicrotime(); for($i=0;$i<=10;$i++){ echo '測試'.time().'<br/>'; sleep($interval);// 等待5s } ob_flush(); flush(); $etime = $curl->getmicrotime(); echo '<hr>'; echo round(($etime-stime),4);//程序執行時間
測試的時候發現這個效率並不是很高。

總結:

個人感覺PHP定時執行任務的效率不是很高,建議關於定時執行任務的工作還是交給shell來做吧。

Ⅶ php如何定時的執行sql語句

在mysql中創建事件,可用於定時執行
CREATE EVENT

CREATE EVENT [IF NOT EXISTS] event_name
ON SCHEDULE schele
[ON COMPLETION [NOT] PRESERVE]
[ENABLE | DISABLE]
[COMMENT 'comment']
DO sql_statement;

Ⅷ php定點執行sql進行對資料庫的操作 應該怎麼做

分兩個步驟:
1. PHP程序里實現:

根據當前系統時間,查出超出三天的數據,並刪除這些數據;

2. 系統定時任務執行步驟1的PHP程序

如果是Linux系統,設置Crontab任務,每天晚上12點執行;
如果是Windows系統,設置計劃任務,每天晚上12點執行。

Ⅸ php mysql 定時每天凌晨3點執行刪除數據任務

mysql定時任務

自 MySQL5.1.6起,增加了一個非常有特色的功能–事件調度器(Event Scheler),可以用做定時執行某些特定任務(例如:刪除記錄、對數據進行匯總等等),來取代原先只能由操作系統的計劃任務來執行的工作。更值得 一提的是MySQL的事件調度器可以精確到每秒鍾執行一個任務,而操作系統的計劃任務(如:Linux下的CRON或Windows下的任務計劃)只能精 確到每分鍾執行一次。對於一些對數據實時性要求比較高的應用(例如:股票、賠率、比分等)就非常適合。

如:每隔30秒將執行存儲過程test,將當前時間更新到examinfo表中id=14的記錄的endtime欄位中去.
CREATE PROCEDURE test ()
BEGIN
update examinfo SET endtime = now() WHERE id = 14;
END;

create event if not exists e_test
on schele every 30 second
on completion preserve
do call test();

2. windows、linux 的定時任務 這個就不舉例了,通過腳本定時去調用mysql執行

Ⅹ PHP實現定時任務的幾種方式

一. 簡單
<?php
ignore_user_abort();//關掉瀏覽器,PHP腳本也可以繼續執行.
set_time_limit(0);// 通過set_time_limit(0)可以讓程序無限制的執行下去
ini_set('memory_limit','512M'); // 設置內存限制
$interval=60*30;// 每隔半小時運行
do{
//ToDo
sleep($interval);// 等待5分鍾
}
while(true);

二. 簡單 可控型

config.php

<?php
return 1;
?>

cron.php

ignore_user_abort();//關掉瀏覽器,PHP腳本也可以繼續執行.
set_time_limit(0);// 通過set_time_limit(0)可以讓程序無限制的執行下去
$interval=60*30;// 每隔半小時運行
do{
$run = include 'config.php';
if(!$run) die('process abort');

//ToDo
sleep($interval);// 等待5分鍾
}
while(true);

三. 簡單 改進型

<?php
$time=15;
$url="http://".$_SERVER['HTTP_HOST'].$_SERVER['REQUEST_URI'];
/*
function
*/
sleep($time);
file_get_contents($url);
?>