亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

php+mysql實現(xiàn)無限級分類及緩存技術(shù)

2020-03-22 20:07:10
字體:
供稿:網(wǎng)友
  • 最近在看一個關(guān)于無限分類的緩存技術(shù)。

    php+mysql緩存技術(shù)的實現(xiàn)

    本教程適合于那些對緩存SQL查詢以減少數(shù)據(jù)庫連接與執(zhí)行的負(fù)載、提高腳本性能感興趣的PHP程序員。
    概述

    許多站點使用數(shù)據(jù)庫作為站點數(shù)據(jù)存儲的容器。數(shù)據(jù)庫包含了產(chǎn)器信息、目錄結(jié)構(gòu)、文章或者留言本,有些數(shù)據(jù)很可能是完全靜態(tài)的,這些將會從一個緩存系統(tǒng)中得到的極大好處。
    這樣一個系統(tǒng)通過把SQL查詢的結(jié)果緩存到系統(tǒng)的一個文件中存儲,從而阻止連接數(shù)據(jù)庫,構(gòu)造查詢與取得返回結(jié)果而提高了響應(yīng)時間。
    有些系統(tǒng)數(shù)據(jù)庫并不是放在WEB服務(wù)器上的,這樣需要一個html' target='_blank'>遠(yuǎn)程連接(TCP或者其它類似的),或者從數(shù)據(jù)庫中獲取大量的數(shù)據(jù),這樣你得忍受更多時間,這決定于系統(tǒng)響應(yīng)時間與資源利用。
    前提

    本教程使用MySQL作為數(shù)據(jù)庫。你需要安裝MySQL(www.mysql.com下載是有效的)和激活PHP MYSQL擴(kuò)展(默認(rèn)情況是激活的)。
    由于要查詢數(shù)據(jù)庫,你需要知識一些SQL(結(jié)構(gòu)化查詢語言)的基本常識。 www.it165.net
    緩存SQL查詢結(jié)果
    為什么要緩存查詢結(jié)果?
    緩存查詢結(jié)果能極大地改進(jìn)腳本執(zhí)行時間和資源需求。
    緩存SQL查詢結(jié)果也允許你通過后期處理數(shù)據(jù)。如果你用文件緩存去存儲全部腳本的輸出結(jié)果(HTML輸出),這樣可能是行不通的。
    當(dāng)你執(zhí)行一個SQL查詢時,點典的處理過程是:
    l 連接數(shù)據(jù)庫
    l 準(zhǔn)備SQL查詢
    l 發(fā)送查詢到數(shù)據(jù)庫
    l 取得返回結(jié)果
    l 關(guān)閉數(shù)據(jù)庫連接
    以上方法非常占用資源并且相反的影響了腳本的性能。只能通過取得的大量返回數(shù)據(jù)和數(shù)據(jù)庫服務(wù)器的位置這二個要素來相互協(xié)調(diào)。盡管持續(xù)連接可以改進(jìn)連接數(shù)據(jù)庫時的負(fù)載,但非常耗費內(nèi)存資源,如果獲取的是大量的數(shù)據(jù),那么存儲的全部時間會非常短暫。
    創(chuàng)建一條SQL查詢:
    SQL(結(jié)構(gòu)化查詢語言)查詢被用作操作數(shù)據(jù)庫及它內(nèi)容的接口。SQL可用于定義和編輯表的結(jié)構(gòu),插入數(shù)據(jù)到表,更新或刪除表中的信息。
    SQL是用于與數(shù)據(jù)通訊的語言,在大多數(shù)PHP數(shù)據(jù)庫擴(kuò)展(MySQL,ODBC,Oracle等)通過傳遞SQL查詢到數(shù)據(jù)庫中來管理整個過程。
    本教程中,僅僅用select語言來獲取數(shù)據(jù)庫中的數(shù)據(jù)。這些數(shù)據(jù)將被緩存,之后將用作數(shù)據(jù)源。
    決定什么時候更新緩存:
    根據(jù)程序的需要,緩存可以采取多種形式。最常見的3種方式是:
    l 時間觸發(fā)緩存(過期的時間戳)
    l 內(nèi)容改變觸發(fā)緩存(發(fā)現(xiàn)數(shù)據(jù)改變后,相應(yīng)地更新緩存)
    l 人工觸發(fā)緩存(人工的方式告知系統(tǒng)信息超期并且強(qiáng)制產(chǎn)生新的緩存)
    你的緩存需求可能是以上原理的一個或多個的綜合。本教程將討論時間觸發(fā)方式。然而,在一個全面的緩存機(jī)制中,3種方式的綜合將被使用。
    緩存結(jié)果:
    基本的緩存是用PHP的兩個函數(shù)serialize()和unserialize()(譯注:這二個函數(shù)分別代表序列化與反序列化)。
    函數(shù)serialize()用于存儲PHP的值,它能保證不失去這些值的類型和結(jié)構(gòu)。
    事實上,PHP的session擴(kuò)展是用序列化過的變量,把session變量($_SESSION)存儲在系統(tǒng)的一個文件中。
    函數(shù)unserialize()與以上操作相反并且使序列化過的字符串返回到它原來的結(jié)構(gòu)和數(shù)據(jù)內(nèi)容。
    在本例中,以一個電子商務(wù)商店為例。商店有2個基本表,categories和products(此處為原始數(shù)據(jù)庫表名).product表可能每天都在變化,categories仍然是不變靜止的。
    要顯示產(chǎn)品,你可以用一個輸出緩存腳本來存儲輸出的HTML結(jié)果到一個文件中。然而categories表可能需要后期處理。例如,所有的目錄通過變量 category_id(通過$_REQUEST['category_id']來取得)被顯示,你可能希望高亮當(dāng)前被選擇的目錄。

    表categories結(jié)構(gòu)
    Field Type Key Extra
    category_id int(10) unsigned PRI auto_incremen
    category_name varchar(255)
    category_description text
    在本例中,通過時間觸發(fā)緩存技術(shù)被運用,設(shè)定一段時間后讓其緩存SQL輸出過期。在此特殊的例子中,定一段時間為24小時。
    序列化例子:


    l 連接數(shù)據(jù)庫
    l 執(zhí)行查詢
    l 取得所有結(jié)果構(gòu)成一個數(shù)組以便后面你可以訪問
    l 序列化數(shù)組
    l 保存序列化過的數(shù)組到文件中*/

    $file = ‘sql_cache.txt’;
    $link = mysql_connect(‘localhost’,'username’,'password’) or die (mysql_error());
    mysql_select_db(‘shop’) or die (mysql_error());

    /* 構(gòu)造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”); // 以寫權(quán)限的方式打開文件
    fputs($fp, $OUTPUT);
    //fwrite($fp,$OUTPUT);
    fclose($fp);

    /*查看sql_cache.txt文件,里面的內(nèi)容可能類似這樣的:
    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”;}}
    這個輸出是它的變量和類型的內(nèi)部表現(xiàn)形式。假若你用mysql_fetch_array()函數(shù)返回數(shù)字索引的數(shù)組和一個關(guān)聯(lián)的數(shù)組(這就是為什么數(shù)據(jù)看起來像是發(fā)生了兩次),一個是數(shù)字索引,另一個是字符串索引。
    使用緩存:
    要用緩存,你需要用函數(shù)unserialize()來使數(shù)據(jù)還原成原始格式與類型。
    你可以用file_get_contents()這個函數(shù)來讀取sql_cache.txt文件的內(nèi)容,把它賦給一個變量。
    請注意:這個函數(shù)在PHP4.3.0及以上版本有效。若你使用的是一個老版本的PHP,一個簡單的方法是用file()函數(shù)(讀整個文件到一個數(shù)組,每行變成一個數(shù)組)。implode()函數(shù)用于把數(shù)組的各元素連接成一個字符串然后使用unserialize()反序列化。*/

    // file_get_contents() 適合于for PHP < 4.3.0
    $file = ‘sql_cache.txt’;
    $records = unserialize(implode(”,file($file)));
    //現(xiàn)在你可以通過$records數(shù)組并且取得原始查詢的數(shù)據(jù):
    foreach ($records as $id=>$row) {
    print $row['category_name'].”<br>”;
    }
    /* 注意$records是數(shù)組(一個包含了查詢結(jié)果的數(shù)字索引列——每行是一個數(shù)字和一個字符串…真是混亂)的一排。
    把它們放在一塊:
    基于本例子中的時間來決定是否緩存。如果文件修改的時間戳比當(dāng)前時間戳減去過期時間戳大,那么就用緩存,否則更新緩存。
    l 檢查文件是否存在并且時間戳小于設(shè)置的過期時間
    l 獲取存儲在緩存文件中的記錄或者更新緩存文件
    $file = ‘sql_cache.txt’;*/
    $expire = 86400; // 24 小時 (單位:秒)
    if (file_exists($file)&&filemtime($file) > (time() – $expire)){
    // 取得緩存中的記錄
    $records = unserialize(file_get_contents($file));
    } else {
    // 通過 serialize() 函數(shù)創(chuàng)建緩存
    }
    /*附加其它可能的:
    l 把緩存結(jié)果存儲在共享內(nèi)存中以獲取更快的速度
    l 增加一個功能隨機(jī)地運行SQL查詢并且檢查是否輸出與緩存輸出一致。如果不一致,則更新緩存(本函數(shù)運行次數(shù)的概率可以定為1/100)。通過哈希算法(如MD5())可以協(xié)助判斷字符串或者文件是否改變。
    l 增加一個管理員的功能,人工的刪除這個緩存文件,以強(qiáng)制更新緩存(如file_exists()函數(shù)返回 false時)。你可以用函數(shù)unlink()刪除文件。
    腳本:*/

    $file = ‘sql_cache.txt’;
    $expire = 86400; // 24 小時
    if (file_exists($file)&&filemtime($file) > (time() – $expire)) {
    $records = unserialize(file_get_contents($file));
    //$records=unserialize(fread($file,filesize($file)));
    } else {
    $link = mysql_connect(‘localhost’,'username’,'password’) or die (mysql_error());
    mysql_select_db(‘shop’) or die (mysql_error());
    /* 構(gòu)造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);
    fwrite($fp,$OUTPUT);
    fclose($fp);
    } // end else

    // 查詢結(jié)果在數(shù)組 $records 中
    foreach ($records as $id=>$row) {
    if ($row['category_id'] == $_REQUEST['category_id']) {
    // 被選擇的目錄顯示粗體字
    print ‘<B>’.$row['category_name'].’</B><BR>’;
    } else {
    // 其它目錄顯示用常規(guī)字體
    print $row['category_name'].’<br>’;
    }
    } // end foreach

    實例:

    $s = microtime(true);$file = './sql_cache.txt';$class_rs = array();if(file_exists($file)){	$class_rs = unserialize(implode('',file($file)));}if(empty($class_rs)){	$My_rs = mysql_query('select * from tbl_province');	while( $row = mysql_fetch_array($My_rs) )	{	   $class_rs[$row['ID']] = $row ;	}	$output = serialize($class_rs);	$fp = fopen($file, 'w');	fputs($fp, $output);	fclose($fp);}function findChild($arr, $pid){	if(!is_array($arr) || $arr == ""){		return $arr;	}	$temp = array();	foreach ($arr as $k=>$v){		if($arr[$k]['PID'] == $pid){			$temp[] = $arr[$k];		}	}	return $temp;}$str = findChild($class_rs, 15);print_r($str);$e = microtime(true);$diff = $e - $s;echo number_format($diff, 10, '.', '')." seconds";

    PHP編程

    鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

  • 發(fā)表評論 共有條評論
    用戶名: 密碼:
    驗證碼: 匿名發(fā)表
    精品黄色免费中文电影在线播放| 国产亚洲精品一区二555| 欧美12av| 免费看黄色aaaaaa 片| 伊人网在线免费| 黄瓜视频免费观看在线观看www| 快播日韩欧美| 一级全黄裸体免费视频| 色播视频在线观看| 亚洲缚视频在线观看| 日韩精品一区二区三区在线播放| 国产精品最新| 热久久最新地址| 欧美天堂在线观看| 日本不良网站在线观看| 欧美黑人又粗又大又爽免费| 最近免费中文字幕大全免费第三页| 国产成人a级片| 91狠狠综合久久久| 日本一级片免费| 欧美激情综合色综合啪啪五月| 久久国产乱子精品免费女| 欧美另类极品| 精品视频免费观看| 日韩大片在线永久免费观看网站| 国产一级片大全| 女人色极品影院| 91精品国产色综合久久| 国产精品久久久久7777按摩| 欧美精品a∨在线观看不卡| 99精品欧美一区二区三区| 成人在线播放| 久久精品国产亚洲高清剧情介绍| 欧美野外多人交3| 亚洲天堂小视频| 国产一区在线观看视频| 国产成人av一区二区三区| 含羞草www国产在线视频| 亚洲综合免费观看高清完整版在线| 92看片淫黄大片看国产片| 麻豆tv在线播放| 大片在线观看网站免费收看| 欧美一区二区视频在线观看2020| 激情综合网最新| 日本成人免费网站| 精品视频在线看| 国产激情视频一区二区| 在线成人av影院| 天堂中文在线官网| 青青青手机在线视频| 日韩在线视频导航| 国产不卡精品在线| 国模无码视频一区二区三区| 国产69精品久久久久按摩| caoporen国产精品| 99久久精品免费看| 日本久久久久| 亚洲精品欧洲精品| 日本精品久久久久久| 有色视频在线观看| 懂色av粉嫩av蜜臀av| 青青热久免费精品视频在线18| 亚洲欧美韩国| 成人私拍视频| 亚洲天堂影院在线观看| 狠狠躁夜夜躁av无码中文幕| 你懂的国产在线| √天堂8资源中文在线| aaa一区二区三区| 中文字幕高清av| 日韩影院免费视频| 99久久视频| 狠狠色丁香久久婷婷综合_中| 欧美午夜精品电影| 亚洲欧美日韩中文在线| 2019日韩中文字幕mv| 精品亚洲一区二区三区四区五区| 好吊妞视频一区二区三区| 亚洲最大福利网| 欧美精品国产精品久久久| 成人国产一区二区三区| 一个人www欧美| 欧美另类videoxo高潮| 欧美在线观看视频| 日韩国产激情| 欧美xxx黑人xxx水蜜桃| 成人免费视频网站在线看| 欧美一级日本a级v片| 黄色小视网站| 国产精品一卡二| 久久亚洲综合国产精品99麻豆精品福利| 日韩精品无码一区二区三区免费| 日日爱66.cn| 999精品视频在线| 九色91蝌蚪| 成人在线看视频| 视频直播国产精品| 九色porny丨精品自拍视频| 国产三级av在线| 国产精品久久久久久久久久妞妞| youjizz国产精品| 2019中文字幕视频| 成人国产精品免费观看| 亚洲精品天天看| 91久久精品一区二区别| 国产美女在线看| 欧美国产欧美亚洲国产日韩mv天天看完整| 99精品人妻无码专区在线视频区| 欧美日韩一区二区三区视视频| 免费在线黄色av| 99久久99久久免费精品蜜臀| 免费在线黄色影片| 国产精选在线观看91| 精品国产美女福利到在线不卡| 一级毛片视频在线| 亚洲欧美日韩国产综合| 亚洲电影小说图| 国产综合 伊人色| 蜜桃av一区二区| 中文字幕日韩第一页| 成人免费无遮挡| 国产真实乱人偷精品人妻| 欧美日韩在线观看视频| 一本色道久久88亚洲综合88| 日韩精品――中文字幕| 色偷偷av亚洲男人的天堂| 豆国产97在线| 欧美成人日本| 日韩av免费播放| 人人玩人人添人人澡免费| 午夜午夜精品一区二区三区文| 亚洲 高清 成人 动漫| 精品国产依人香蕉在线精品| 永久免费看av| 国产不卡视频在线观看| 全球成人免费直播| 最近中文字幕一区二区三区| 亚洲午夜国产成人av电影男同| 精品久久久久久久久久久久久久久久| 丝袜人妻一区二区三区| 欧美日韩久久一区二区| 波多野结衣在线观看一区| 7788色淫网站小说| 老司机免费视频一区二区三区| 77777少妇光屁股久久一区| 日本亚洲欧洲无免费码在线| 精品视频资源站| 三级黄色片在线观看| 亚洲人成五月天| 男人资源在线播放| av小说在线| 亚洲激情一区二区三区| 久久国产日本精品| 亚洲免费资源在线播放| 2019中文字幕在线视频| 国产成人在线看| 任你操视频在线观看| 亚洲人在线观看视频| 精品人妻一区二区三区四区不卡| 欧美性xxxx极品hd欧美风情| 在线播放中文一区| 日韩电影在线免费| 亚洲综合视频网站| 亚洲欧美日韩一区成人| 国产精品第8页| 国产精品免费视频二三区| 国产精品剧情一区二区在线观看| 成人av.网址在线网站| 日韩成人精品在线| 久久男女视频| 亚洲欧美久久久| 粉嫩av一区二区三区四区五区| av网址在线看| 精品久久久久久久一区二区蜜臀| 无吗不卡中文字幕| 国产尤物99| 久久久久中文字幕亚洲精品| 无人在线观看的免费高清视频| 亚洲成av人片一区二区| 免费看毛片网站| 男女羞羞视频教学| 影视一区二区| 精品少妇爆乳无码av无码专区| 国产精品亚洲成人| 日韩亚洲欧美成人| 国产呦系列欧美呦日韩呦| 五月天福利视频| jvid福利在线一区二区| 欧美一级特黄aaaaaa在线看片| 亚洲午夜久久久久久久久红桃| 欧美激情影音先锋| 国产一区二区剧情av在线| 僵尸再翻生在线观看免费国语| 国产成人精品亚洲精品色欲| 日韩精品成人一区二区在线| 精品美女www爽爽爽视频| 欧美在线观看网址综合| 成人在线播放| 午夜免费在线| 精品福利一二区| 国产日本欧美一区二区| 国产在线日韩精品| 久久久久免费精品国产| 都市激情亚洲综合| 成年人看的羞羞网站| 亚洲成av人片观看| 久久视频精品在线| 欧美一区二区三区久久精品| 中文字幕在线直播| 小次郎av收藏家| 日韩在线视频播放| av手机在线播放| 日韩视频免费在线播放| 国产精品综合视频| 亚洲欧美综合7777色婷婷| 高清亚洲高清| 日韩三级av在线播放| 亚洲高清在线一区| 国产一区二区在线不卡| 日韩欧美一二三| 亚洲人123区| 天堂成人免费av电影一区| 亚洲二区av| 中文字幕免费在线观看视频| av在线电影网| wwww国产精品欧美| 女王人厕视频2ⅴk| 日韩av中文字幕第一页| caoporn免费在线| 91美剧网在线播放| 欧美绝顶高潮抽搐喷水合集| 久久国产精品色| 国产亚洲精久久久久久| 禁网站在线观看免费视频| 国产午夜精品一区二区理论影院| 免费高清在线一区| 日本少妇激情视频| 天天躁夜夜躁狠狠是什么心态| 精品无码av在线| 91精品国产91久久久久久吃药| 91视频 -- 69xx| 伊人成年综合电影网| 日韩欧美高清一区二区三区| 国产精彩视频一区二区| 国产成人精品免费久久久久| 日韩有吗在线观看| 亚洲人成亚洲人成在线观看| 久久久在线免费观看| 亚洲欧洲一级| 91极品视频在线观看| 中文视频一区视频二区视频三区| 丰满的少妇愉情hd高清果冻传媒| 鲁丝一区二区三区| 国产精品久久久久久免费免熟| 国色天香2019中文字幕在线观看| 欧美怡红院在线| 五十路亲子中出在线观看| 中文字幕亚洲高清| 成人在线短视频| 免费黄色av网址| 国产在线观看不卡一区二区三区| 亚洲AV无码成人片在线观看| 亚洲成人影音| 老司机午夜福利视频| 国产精品无码天天爽视频| 日韩视频一区二区三区在线播放免费观看| 国产三级久久久| 午夜免费入口| 久久亚洲精品国产亚洲老地址| 亚洲区小说区图片区qvod| 亚洲老妇xxxxxx| 久久99久久99精品中文字幕| 美州a亚洲一视本频v色道| 久久久久久久久99精品大| 妖精视频一区二区三区| 青春草国产成人精品久久| 亚洲综合图片区| 一区二区三区91| 国产一区二区免费在线| 久久综合亚洲色hezyo国产| 国产丝袜欧美中文另类| 糖心vlog精品一区二区| 国产日韩欧美精品综合| 91一区在线观看| 亚洲精品在线三区| 中文字幕免费观看视频| 交100部在线观看| 国产一二三四五| 日韩和欧美一区二区三区| 免费视频一区| www.黄色在线| 久久免费国产视频| 欧美一级片免费| 黄色一级大片在线免费看产| www.日本久久久久com.| 77thz桃花论族在线观看| 国产精品欧美久久久久一区二区| 天天鲁一鲁摸一摸爽一爽| 国产精品一区二区三| 神马影院我不卡午夜| 欧美激情综合五月色丁香| 视频在线观看一区| 国产精品天干天干在观线| 国产精品成人一区二区网站软件| 乱小说欧美综合| a级网站在线观看| 国产不卡在线一区| 9久久9毛片又大又硬又粗| 成人高潮免费视频| 成人精品视频久久久久| 国产免费1000拍拍拍| 国产丝袜护土调教在线视频| 亚洲精品观看| 国产亚洲日本欧美韩国| 五月天视频在线观看| 日韩一区二区三区免费播放| 亚洲国产天堂| 国产精品盗摄久久久| gogo久久| 看全色黄大色大片免费久久久| 三级黄色片播放| 91av在线播放视频| 国产成年人在线观看| 精品免费日产一区一区三区免费| 精品欧美一区二区三区在线观看| 精品视频高清无人区区二区三区| 亚洲综合在线一区二区| 亚洲第一精品久久忘忧草社区|