在PHP開發中對資料庫進行操作是非常常見的,我們在一個頁面停留長時間不操作會有提示或報錯等情況相信大家也都遇到過,那麼今天我們就來講一下如何對資料庫進行操作以及防止頁面超時!
說明:
對資料庫進行初始化或修改等操作時:
1、簡單的直接使用sql語句完成。
2、稍微複雜一點,可以透過執行php程式碼來完成(讀資料再寫/修改資料)。
使用php程式碼的時候(非命令列),我們可能會遇到網頁超時的情況,解決方法一般有三種:
1、設定php.ini:
max_execution_time
2、程式碼中新增:
set_time_limit(0); //0表示不超时
3、頁面自動刷新,整個工作分批完成:
頁面可以隨著執行的流程而變化,例如動態地告訴使用者執行到多少了,而不是單一頁面的等待。
下面,主要整理了一下第三種方式。
頁面自動刷新:
頁面刷新<==>頁面跳轉,當某個條件成立時停止跳轉。
頁面跳轉:輸出meta標籤來實現
if ($flag) { //跳转页面,xxx为该php文件的文件名 echo '<meta http-equiv="refresh" content="0;url=xxx.php?">'; } else { //刷新停止 }
刷新同時傳遞參數,控制資料庫操作:
在meta的url中,我們可以使用Get的方式來傳遞一個參數。
這個參數可以用來變化SQL語句的limit,而實作每次執行一部分的功能。
$page = isset($_GET['page']) ? $_GET['page'] : 0; //用$page构造sql语句或其它功能 //数据库操作或其它功能 //设置$flag $flag = $pdostatement->rowCount() == 0; //比如数据库影响行数 //决定 跳转刷新 或 停止 if ($flag) { //跳转页面,xxx为该php文件的文件名 echo '<meta http-equiv="refresh" content="0;url=xxx.php?page=' . ++$page . '">'; } else { //刷新停止 }
假設,對某欄位資料+1,具體實作:
現在對SQL還不是很熟悉。
如果只是limit限制,可能會出現:已被查詢過的資料 再次被查詢出來 執行第二遍的情況?
個人覺得,最好加上主鍵的order by
<meta charset="UTF-8"> <?php $page = isset($_GET['page']) ? $_GET['page'] : 0; $step = 50; //每次刷新更新 50条数据 $limit_start = $page * 50; $dsn = "mysql:host=localhost;dbname=db_name"; try { $pdo = new PDO($dsn, "root", "123456"); $sql = <<<SQL SELECT col_num, col_id FROM table_name ORDER by col_id LIMIT {$limit_start},{$step} SQL; $pdostatement = $pdo->prepare($sql); $pdostatement->execute(); $pdostatement->setFetchMode(PDO::FETCH_NUM); $num = $pdostatement->rowCount(); if ($num == 0) { echo "sql执行完毕"; } else { echo "正在执行sql<br>"; $sql_update = "UPDATE table_name "; while (list($col_num, $col_id) = $pdostatement->fetch(PDO::FETCH_NUM)) { $col_name++; $sql_update .= <<<SQL SET col_name = "{$col_num}" WHERE col_id = "{$col_id}" , SQL; } $sql_update = substr($sql_update, 0, -1); //去掉最后的逗号 $pdostatement_update = $pdo->prepare($sql_update); $pdostatement_update->execute(); $num_update = $pdostatement_update->rowCount(); if ($num_update == 0) { echo $gfc_id . "修改出错,停止更新"; } else { echo '<meta http-equiv="refresh" content="0;url=jianshu.php?page=' . (++$page) . '">'; } } } catch (PDOException $e) { echo "数据库连接失败" . $e->getMessage(); //连接失败,获取错误信息 exit; }
以上就是PHP如何進行資料庫操作以及防止頁面超時和自動刷新頁面的所有內容,這些方法在我們的PHP開發中都是很長用的也是很長見的。
類似文章:
以上是PHP如何進行資料庫操作以及防止頁面逾時和自動刷新頁面講解的詳細內容。更多資訊請關注PHP中文網其他相關文章!