這篇文章主要介紹了關於php資料庫快取實現思路,有著一定的參考價值,現在分享給大家,有需要的朋友可以參考一下
快取SQL查詢結果 為什麼要快取查詢結果? 快取查詢結果能大幅改善腳本執行時間和資源需求。 快取SQL查詢結果也允許你透過後製資料。如果你用檔案快取去儲存全部腳本的輸出結果(HTML輸出),這樣可能是行不通的。 當你執行一個SQL查詢時,點典的處理過程是: 437fcc348f7b1c54dc1b8f8cb5743cbcl 1e9a002b7a5c51d4c124ad105ca31a96連接資料庫 437fcc348f7b1c54dc1b8f8cb5743cbcl 04c6c2c265887a55041405a81efec09a準備SQL查詢 de2704426fb11824f34855f8c48ad320l 04c6c2c265887a55041405a81efec09a寄查詢至資料庫 保存序列化過的陣列到檔案中 [php] view plaincopy $file = 'sql_cache.txt'; $link = mysql_connect('localhost','username','password') or die (mysql_error()); mysql_select_db('shop') or die (mysql_error()); /* 构造SQL查询 */ $query = "SELECT * FROM categories"; $result = mysql_query($query) or die (mysql_error()); while ($record = mysql_fetch_array($result) ) { $records[] = $record; } $OUTPUT = serialize($records); $fp = fopen($file,"w"); // 以写权限的方式打开文件 fputs($fp, $OUTPUT); fclose($fp); 查看sql_cache.txt文件,裡面的內容可能類似這樣的: a:1:{i:0;a:6:{i:0;s:1:"1";s:11:"category_id";s:1 :"1";i:1;s:9:"Computers";s:13:"category_name";s:9: "Computers" ;i:2;s:25:"Description for computers";s:20:"category_description" ;s:25:"Description for computers";}} 這個輸出是它的變數和類型的內部表現形式。假若你用mysql_fetch_array()函數傳回數字索引的陣列和一個關聯的陣列(這就是為什麼資料看起來像是發生了兩次),一個是數字索引,另一個是字串索引。 使用快取: 要用緩存,你需要用函數unserialize()來讓資料還原成原始格式與型別。 你可以用file_get_contents()這個函數來讀取sql_cache.txt檔案的內容,把它賦給一個變數。 請注意:這個函數在PHP4.3.0以上版本有效。若你使用的是一個舊版的PHP,一個簡單的方法是用file()函數(讀整個檔到一個數組,每行變成一個數組)。 implode()函數用來把陣列的各元素連接成一個字串然後使用unserialize()反序列化。 // file_get_contents() 適合for PHP < 4.3.0 [php] view plaincopy $file = 'sql_cache.txt'; $records = unserialize(implode('',file($file))); //现在你可以通过$records数组并且取得原始查询的数据: foreach ($records as $id=>$row) { print $row['category_name']."<br>"; } 注意$records是陣列(一個包含了查詢結果的數字索引列——每行是一個數字和一個字串...真是混亂)的一排。 把它們放在一塊: 基於本範例中的時間來決定是否快取。如果檔案修改的時間戳比目前時間戳記減去過期時間戳大,那麼就用緩存,否則更新快取。 437fcc348f7b1c54dc1b8f8cb5743cbcl 04c6c2c265887a55041405a81efec09a檢查檔案是否存在且時間戳小於設定的過期時間 437fcc348f7b1c54dc1b8f8cb5743cbcl 04c6c2c265887a55041405a81efec09a取得儲存在快取檔案中的記錄或更新快取檔案 #[ #[ php] view plaincopy 437fcc348f7b1c54dc1b8f8cb5743cbcl dbe2c03495b4fb6333780cfaab47e0b0把快取結果儲存在共享記憶體中以獲得更快的速度 437fcc348f7b1c54dc1b8f8cb5743cbcl d32db65dbc61dd80d4bed366bbf06d61增加一個功能隨機運行SQL查詢並且檢查是否輸出與快取輸出一致。如果不一致,則更新快取(本函數運行次數的機率可以設定為1/100)。透過哈希演算法(如MD5())可以協助判斷字串或檔案是否改變。 437fcc348f7b1c54dc1b8f8cb5743cbcl 04c6c2c265887a55041405a81efec09a增加一個管理員的功能,人工的刪除這個快取文件,以強制更新快取(如file_exists()函數傳回false時)。你可以用函數unlink()刪除檔案。 #腳本:[php] view plaincopy $file = 'sql_cache.txt'; $expire = 86400; // 24 小时 if (file_exists($file) && filemtime($file) > (time() - $expire)) { $records = unserialize(file_get_contents($file)); } else { $link = mysql_connect('localhost','username','password') or die (mysql_error()); mysql_select_db('shop') or die (mysql_error()); /* 构造SQL查询 */ $query = "SELECT * FROM categories"; $result = mysql_query($query) or die (mysql_error()); while ($record = mysql_fetch_array($result) ) { $records[] = $record; } $OUTPUT = serialize($records); $fp = fopen($file,"w"); fputs($fp, $OUTPUT); fclose($fp); } // end else // 查询结果在数组 $records 中 foreach ($records as $id=>$row) { if ($row['category_id'] == $_REQUEST['category_id']) { // 被选择的目录显示粗体字 print '<B>'.$row['category_name'].'</B><BR>'; } else { // 其它目录显示用常规字体 print $row['category_name'].'<br>'; } } // end foreach |
以上是php資料庫快取實作思路的詳細內容。更多資訊請關注PHP中文網其他相關文章!