国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 數據庫 > MySQL > 正文

php+mysql實現無限級分類及緩存技術

2020-03-22 20:07:10
字體:
來源:轉載
供稿:網友
  • 最近在看一個關于無限分類的緩存技術。

    php+mysql緩存技術的實現

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

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

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

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


    l 連接數據庫
    l 執行查詢
    l 取得所有結果構成一個數組以便后面你可以訪問
    l 序列化數組
    l 保存序列化過的數組到文件中*/

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

    // 查詢結果在數組 $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

    實例:

    $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編程

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

  • 發表評論 共有條評論
    用戶名: 密碼:
    驗證碼: 匿名發表
    国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
    超碰97国产精品人人cao| 福利视频在线导航| 午夜国产视频| www.操.com| 九九99精品| 91超碰在线免费| 91sp网站在线观看入口| 国产无遮挡又黄又爽免费软件| 国产寡妇树林野战在线播放| 国产精品jvid在线观看| 在线三级av| 香蕉视频在线观看www| 九九热在线观看视频| 国产精品视频一区二区免费不卡| 91在线高清| 天天操天天曰| 国产福利资源| 狂野欧美性猛交xxxx乱大交| 国产青草视频在线观看视频| 午夜影院免费看| 国产精品伦一区二区三区视频 | 97最新国自产拍视频在线完整在线看| 国产福利在线| 麻豆福利在线观看| 国产a国产a国产a| 国产在线视频福利| www.av在线视频| 97高清视频| 欧美色第一页| 91在线网址| 国产亚洲精品午夜高清影院| gogogogo高清视频在线| 国产成人天天5g影院| 国产羞羞视频在线观看| 久草网在线视频| 亚洲成人av在线影院| 国产精品国产三级国产试看| 国产美女视频网站| 国产麻豆精品入口在线观看 | 青青草中文字幕| 国产精品欧美韩国日本久久| 国产免费专区| 免费av在线| 欧美卡一卡二| av在线官网| gogogogo高清视频在线| 日本免费视频www| 国产精品久久精品牛牛影视| 美女网站在线观看| 麻豆精品传媒视频观看| 久久久久久77777| 九九在线免费视频| 国产视频福利在线| 最新天堂资源在线资源| 国产免费高清| 国产在线高潮| 国产素人视频在线观看| 国产不卡一卡2卡三卡4卡5卡在线| 国产乱子伦三级在线播放| 国产一级性片| 精品国内一区二区三区免费视频| 国产欧美黑人| www.蜜桃av| 午夜视频99| 99re6在线视频精品免费| 天堂√中文在线| 热99re久久精品精品免费| 狠狠色综合久久婷婷| 蜜桃视频中文字幕| 国产网红女主播精品视频| 国产精品臀控福利在线观看| 国产黄视频在线观看| av在线中文| 国产精品久久一区二区三区不卡| 91中文在线| 九九热视频免费在线观看| 天天操夜夜摸| www.xxx黄| 91涩漫在线观看c| 黄色电影网站在线观看| 国产不卡视频| 国产精品臀控福利在线观看| 亚洲欧美久久婷婷爱综合一区天堂 | 精品视频一二三| 亚洲色婷婷综合开心网| 亚洲欧美日韩综合精品网| 国产午夜三区视频在线| www.操操操.com| 99在线免费观看| 国产二区视频在线观看| 欧美日韩一区二区三区视视频 | 国产高清免费视频| 亚洲精品成人a| 国产日产一区二区三区| 青青青青在线| 亚洲欧美久久婷婷爱综合一区天堂| 四虎成人欧美精品在永久在线| 日本中文字幕在线播放| 久久久久久91精品色婷婷| 白浆爆出在线观看| 日日夜夜中文字幕| 尤物视频在线观看视频| 国产精品久久久高清免费| 国产系列在线观看| 最近中文字幕mv免费高清电影| 牛牛精品视频在线| 日本国产在线| 九九热在线视频观看| 久草国产视频| 国产小视频免费在线观看| 国产黄色av免费看| 国产小视频免费在线网址| 国产免费电影网站入口| 最近免费中文字幕在线第一页| 国产精品一二三区视频| 国产精品99999| 国产超碰精品在线观看| 在线黄色国产电影| 久久久久久77777| 国产精品一区二三区| 国产污视频在线| 精品视频一二三| а√资源新版在线天堂| 成人免费一区二区三区牛牛| 国产一级免费| 亚洲激情丁香| 欧美a免费在线| 天堂在线亚洲| 99热最新网址| jlzzjlzz欧美大全| 久久er视频| 综合图区亚洲白拍在线 | 超碰在线97国产| 国产私人尤物无码不卡| 91九色在线看| 欧美日韩在线精品成人综合网| 最新中文字幕在线| 本道综合精品| 2019年中文字幕| 色吊丝av中文字幕| 国产福利小视频在线观看 | 天天插天天操| 国产天堂av| 国产精品入口麻豆免费看| 亚洲日本伊人| 精品视频vs精品视频| 天天操天天操一操| 四虎在线免费视频| 中文日本在线观看| 二区三区中文字幕| 毛片网站在线观看| 在线观看免费观看在线91| 超碰在线97国产| 香蕉视频网站在线观看| 国产福利电影在线观看| 天天av综合网| 国产一级在线| 国产小视频在线高清播放| 亚洲精品天堂在线观看| 国产精品福利视频一区二区三区| 成人无遮挡免费网站视频在线观看| 亚洲夜夜综合| 色欧美在线观看| 亚洲v片在线观看| 日本一级理论片在线大全| av手机天堂| 9999在线视频| 国产精品久久久久久久牛牛| 高潮白浆视频| **三级三级97片毛片| 国产亚洲精品自在线观看| 国产69精品久久久久孕妇国产69久久 | 国产成人精品实拍在线| 日本综合一区二区三区| 国产午夜视频在线观看| 在线观看国产福利视频| 国产亚洲精品一区二区在线观看| 四虎成年永久免费网站| a视频免费看| 中文在线官网天堂| 中文字幕av在线| 性网站在线观看| 丁香婷婷在线| 国产亚洲精品久久久久久青梅| 国产视频青青| 日本高清中文字幕| 国产原创av在线| 精品一区二区在线欧美| 天天干天天操天天爽| 男人天堂99| 18加网站在线| www.中文字幕久久久| 导航福利在线| 91免费日韩| 国产免费麻豆视频| 白浆爆出在线观看| 在线视频观看国产| 国产色视频网站| 久热中文字幕精品视频在线| 国产区视频在线播放|