smarty緩存用法分析
本文詳細(xì)分析了smarty緩存的用法。分享給大家供大家參考。具體分析如下:
一開(kāi)始以為smarty只是用來(lái)做一些掩飾php代碼功能,但是后來(lái)才知道還有模板緩存這個(gè)強(qiáng)大的功能。
什么是模板緩存呢,就是我們?cè)趶臄?shù)據(jù)庫(kù)里面取出一些數(shù)據(jù)輸出到模板的訪(fǎng)問(wèn)的時(shí)候,每一次都對(duì)數(shù)據(jù)庫(kù)進(jìn)行訪(fǎng)問(wèn),但是其實(shí)每一次的數(shù)據(jù)庫(kù)訪(fǎng)問(wèn)都是相同的,假如網(wǎng)址的流量很大,這種重復(fù)的訪(fǎng)問(wèn)完全是沒(méi)有必要的,對(duì)于數(shù)據(jù)庫(kù)有很大壓力。smarty就提供了緩存技術(shù),用于解決這個(gè)問(wèn)題。
首先使用smarty的緩存,我們有一些要設(shè)置的:
開(kāi)啟緩存
設(shè)置緩存周期
設(shè)置緩存目測(cè)
然后對(duì)于數(shù)據(jù)庫(kù)訪(fǎng)問(wèn)的那一部分,我們首先做一次判斷,是否已經(jīng)對(duì)此部分進(jìn)行過(guò)緩存了
$conn = mysql_connect('localhost','root','root');
mysql_query('set names utf8');
mysql_query('use market');
$rs = mysql_query('select goods_id,goods_name,shop_price,add_time from goods where goods_id = ' . $goods_id,$conn);
$goods =array();
while($row = mysql_fetch_assoc($rs)){
$goods[] = $row;
}
echo '走了數(shù)據(jù)庫(kù)';
$Smarty->assign('goods);
}
但是在smarty的緩存里面還有需要注意的地方,就是假如從地址欄里面get的參數(shù),那么就有可能影響到緩存,多個(gè)不同的參數(shù)只緩存了第一次生成的,所以這里就需要用到單模板多緩存技術(shù),其實(shí)也很簡(jiǎn)單,只要在
那么這個(gè)緩存要怎么刪除呢,很簡(jiǎn)單,只需要調(diào)用
最后,有時(shí)候在調(diào)試程序的時(shí)候不緩存,我們也可以設(shè)置這個(gè)參數(shù)用于暫時(shí)停止緩存:
最后有一點(diǎn)注意,緩存的生命周期是指,在這個(gè)時(shí)間過(guò)了以后,再次刷新這個(gè)頁(yè)面會(huì)用新的緩存代替舊的,假如不產(chǎn)生新的緩存,那么舊的緩存是不會(huì)自動(dòng)刪除的,所以在實(shí)際項(xiàng)目開(kāi)發(fā)中,假如緩存很多的話(huà),其實(shí)也是很影響存儲(chǔ)的。
其實(shí)我們需要緩存的也只是很少一部分的HTML,現(xiàn)在很多站都使用了memcached來(lái)緩存。
希望本文所述對(duì)大家的PHP程序設(shè)計(jì)有所幫助。
相關(guān)文章
關(guān)于ob_get_contents(),ob_end_clean(),ob_start(),的具體用法詳解
本篇文章是對(duì)ob_get_contents(),ob_end_clean(),ob_start(),的具體用法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-06-06
php數(shù)組分頁(yè)實(shí)現(xiàn)方法
這篇文章主要介紹了php數(shù)組分頁(yè)實(shí)現(xiàn)方法,涉及php數(shù)組操作、數(shù)學(xué)運(yùn)算及字符串操作等相關(guān)技巧,需要的朋友可以參考下2016-04-04
phpmyadmin顯示utf8_general_ci中文亂碼的問(wèn)題終級(jí)篇
自己寫(xiě)PHP也有一年多了,然后編碼問(wèn)題卻老是沒(méi)有得到好的解決,自己的情況是這樣的,網(wǎng)頁(yè)顯示完全正常,在phpmyadmin數(shù)據(jù)庫(kù)顯示中文亂碼,不管是簡(jiǎn)體還是繁體,只要是中文都是亂碼2013-04-04

