溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

smarty 緩存

發布時間:2020-08-06 05:37:06 來源:網絡 閱讀:507 作者:菜鳥不菜么 欄目:web開發

頁面緩存

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}


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女