頁面緩存
1.先使用數據庫加載一組數據。
//PDO 數據庫連接
$pdo = new PDO('mysql:host=localhost;dbname=grade', 'root', '123456');
//設置字符集
$pdo->query('SET NAMES UTF8');
//得到準備對象
$stmt = $pdo->prepare("SELECT * FROM one");
//執行 SQL 語句
$stmt->execute();
//初始化
$object = [];
//組裝數據列表
while ($rows = $stmt->fetchObject()) {
$object[] = $rows;
}
//輸出顯示
echo '執行了數據庫操作';
$smarty->assign('object', $object);
$smarty->display('12.tpl');
<table border="1">
<tr>
<th>姓名</th>
<th>數學</th>
<th>語文</th>
<th>英語</th>
</tr>
{foreach from=$object item=obj}
<tr>
<td>{$obj->user}</td>
<td>{$obj->math}</td>
<td>{$obj->chinese}</td>
<td>{$obj->english}</td>
</tr>
{/foreach}
</table>
暴露問題:這張數據表,可能很長時間不會有所改動,比如一天,一周,一個月都不會
改動。但是,用戶每次訪問,都要經過數據庫,造成性能上的極大浪費。這時,我們想通過
緩存技術,將第一次生成的頁面靜態化,然后以后就訪問這個靜態頁面,從而避免執行數據
庫操作。
2.開啟緩存
//在配置文件里開啟緩存設置
$smarty->caching = true;
//緩存的目錄,第一次會自動生成
$smarty->cache_dir = 'cache';
刷新頁面后,會自動生成 cache 目錄。并生成了一個靜態頁面,下次訪問是會訪問這
個靜態頁面。不會因為數據庫數據改變,而發生變化。但是,這個地方還是有問題的,雖然
訪問的是靜態頁面。但并沒有說,不執行 PHP 連接數據庫,執行數據庫這個步驟,所以,
我們還需要進行靜態頁面的判斷工作。
3.判斷緩存
//判斷緩存是否存在
if (!$smarty->isCached('12.tpl')) {
}
先判斷緩存是否存在,然后再執行 PHP 代碼(包括執行數據庫連接和執行)。如果存
在緩存,就直接忽略 PHP 代碼部分,直接讀取緩存,這樣避免數據庫執行浪費。
二.局部不緩存
1.使用{nocache}...{/nocache}讓局部不緩存。
{nocache}
{$smarty.now|date_format:"Y-m-d H:i:s"}
{/nocache}
2.如果不緩存的內容本身是標簽,可以在標簽后直接加上 nocache 即可。
{$smarty.now|date_format:"Y-m-d H:i:s" nocache}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。