Memcache 在PHP中的使用技巧
更新時(shí)間:2010年02月08日 09:55:06 作者:
Memcache 在PHP中的使用
add($key, $value, $expiry);
$key: 唯一標(biāo)識(shí), 用于區(qū)分寫入的數(shù)據(jù)
$value: 要寫入的數(shù)據(jù)
$expiry: 過期時(shí)間, 默認(rèn)為永遠(yuǎn)有效
用途: 將數(shù)據(jù)寫入到memcache中
get($key)
$key: 通過寫入時(shí)的$key獲取對(duì)應(yīng)的數(shù)據(jù)
用途: 獲取memcache中的數(shù)據(jù)
replace($key, $value, $expiry)
該方法參數(shù)與add方法的參數(shù)相同
用途也很明顯就是替換數(shù)據(jù)
delete($key, $time = 0)
$key: 唯一標(biāo)識(shí)
$time: 延遲時(shí)間
用途: 刪除memcache中存儲(chǔ)的數(shù)據(jù)
下面來(lái)看看具體用法:
add($key, $value, $expiry);
$key: 唯一標(biāo)識(shí), 用于區(qū)分寫入的數(shù)據(jù)
$value: 要寫入的數(shù)據(jù)
$expiry: 過期時(shí)間, 默認(rèn)為永遠(yuǎn)有效
用途: 將數(shù)據(jù)寫入到memcache中
get($key)
$key: 通過寫入時(shí)的$key獲取對(duì)應(yīng)的數(shù)據(jù)
用途: 獲取memcache中的數(shù)據(jù)
replace($key, $value, $expiry)
該方法參數(shù)與add方法的參數(shù)相同
用途也很明顯就是替換數(shù)據(jù)
delete($key, $time = 0)
$key: 唯一標(biāo)識(shí)
$time: 延遲時(shí)間
用途: 刪除memcache中存儲(chǔ)的數(shù)據(jù)
下面來(lái)看看具體用法:
代碼
<?php
$m = new Memcache();
$m->connect('localhost', 11211);
$data = 'content'; //需要緩存的數(shù)據(jù)
$m->add('mykey', $data);echo $m->get('mykey'); // 輸出 content
$m->replace('mykey', 'data'); //替換內(nèi)容為dataecho $m->get('mykey');//輸出 data
$m->delete('mykey'); //刪除echo $m->get('mykey'); //輸出 false 因?yàn)橐呀?jīng)刪掉了哦..
?>
是不是很簡(jiǎn)單.. 在實(shí)際應(yīng)用中,通常會(huì)把數(shù)據(jù)庫(kù)查詢的結(jié)果集保存到 memcached 中
下次訪問時(shí)直接從 memcached 中獲取,而不再做數(shù)據(jù)庫(kù)查詢操作,這樣可以在很大程度上減輕數(shù)據(jù)庫(kù)的負(fù)擔(dān)。
通常會(huì)將 SQL 語(yǔ)句 md5() 之后的值作為唯一標(biāo)識(shí)符 key。下邊是一個(gè)利用 memcached 來(lái)緩存數(shù)據(jù)庫(kù)查詢結(jié)果集的示例
代碼
<?php
//連接memcache
$m = new Memcache();
$m->connect('localhost', 11211);
//連接數(shù)據(jù)庫(kù)的我就不寫了.
$sql = 'SELECT * FROM users';
$key = md5($sql); //md5 SQL命令 作為 memcache的唯一標(biāo)識(shí)符
$rows = $m->get($key); //先重memcache獲取數(shù)據(jù)
if (!$rows) {
//如果$rows為false那么就是沒有數(shù)據(jù)咯, 那么就寫入數(shù)據(jù)
$res = mysql_query($sql);
$rows = array();
while ($row = mysql_fetch_array($res)) {
$rows[] = $row;
}
$m->add($key, $rows);
//這里寫入重?cái)?shù)據(jù)庫(kù)中獲取的數(shù)據(jù), 可以設(shè)置緩存時(shí)間, 具體時(shí)間設(shè)置多少, 根據(jù)自己需求吧.
}
var_dump($rows); //打印出數(shù)據(jù)
//上面第一次運(yùn)行程序時(shí), 因?yàn)檫€沒有緩存數(shù)據(jù), 所以會(huì)讀取一次數(shù)據(jù)庫(kù), 當(dāng)再次訪問程序時(shí), 就直接重memcache獲取了.
?>
$key: 唯一標(biāo)識(shí), 用于區(qū)分寫入的數(shù)據(jù)
$value: 要寫入的數(shù)據(jù)
$expiry: 過期時(shí)間, 默認(rèn)為永遠(yuǎn)有效
用途: 將數(shù)據(jù)寫入到memcache中
get($key)
$key: 通過寫入時(shí)的$key獲取對(duì)應(yīng)的數(shù)據(jù)
用途: 獲取memcache中的數(shù)據(jù)
replace($key, $value, $expiry)
該方法參數(shù)與add方法的參數(shù)相同
用途也很明顯就是替換數(shù)據(jù)
delete($key, $time = 0)
$key: 唯一標(biāo)識(shí)
$time: 延遲時(shí)間
用途: 刪除memcache中存儲(chǔ)的數(shù)據(jù)
下面來(lái)看看具體用法:
add($key, $value, $expiry);
$key: 唯一標(biāo)識(shí), 用于區(qū)分寫入的數(shù)據(jù)
$value: 要寫入的數(shù)據(jù)
$expiry: 過期時(shí)間, 默認(rèn)為永遠(yuǎn)有效
用途: 將數(shù)據(jù)寫入到memcache中
get($key)
$key: 通過寫入時(shí)的$key獲取對(duì)應(yīng)的數(shù)據(jù)
用途: 獲取memcache中的數(shù)據(jù)
replace($key, $value, $expiry)
該方法參數(shù)與add方法的參數(shù)相同
用途也很明顯就是替換數(shù)據(jù)
delete($key, $time = 0)
$key: 唯一標(biāo)識(shí)
$time: 延遲時(shí)間
用途: 刪除memcache中存儲(chǔ)的數(shù)據(jù)
下面來(lái)看看具體用法:
代碼
復(fù)制代碼 代碼如下:
<?php
$m = new Memcache();
$m->connect('localhost', 11211);
$data = 'content'; //需要緩存的數(shù)據(jù)
$m->add('mykey', $data);echo $m->get('mykey'); // 輸出 content
$m->replace('mykey', 'data'); //替換內(nèi)容為dataecho $m->get('mykey');//輸出 data
$m->delete('mykey'); //刪除echo $m->get('mykey'); //輸出 false 因?yàn)橐呀?jīng)刪掉了哦..
?>
是不是很簡(jiǎn)單.. 在實(shí)際應(yīng)用中,通常會(huì)把數(shù)據(jù)庫(kù)查詢的結(jié)果集保存到 memcached 中
下次訪問時(shí)直接從 memcached 中獲取,而不再做數(shù)據(jù)庫(kù)查詢操作,這樣可以在很大程度上減輕數(shù)據(jù)庫(kù)的負(fù)擔(dān)。
通常會(huì)將 SQL 語(yǔ)句 md5() 之后的值作為唯一標(biāo)識(shí)符 key。下邊是一個(gè)利用 memcached 來(lái)緩存數(shù)據(jù)庫(kù)查詢結(jié)果集的示例
代碼
復(fù)制代碼 代碼如下:
<?php
//連接memcache
$m = new Memcache();
$m->connect('localhost', 11211);
//連接數(shù)據(jù)庫(kù)的我就不寫了.
$sql = 'SELECT * FROM users';
$key = md5($sql); //md5 SQL命令 作為 memcache的唯一標(biāo)識(shí)符
$rows = $m->get($key); //先重memcache獲取數(shù)據(jù)
if (!$rows) {
//如果$rows為false那么就是沒有數(shù)據(jù)咯, 那么就寫入數(shù)據(jù)
$res = mysql_query($sql);
$rows = array();
while ($row = mysql_fetch_array($res)) {
$rows[] = $row;
}
$m->add($key, $rows);
//這里寫入重?cái)?shù)據(jù)庫(kù)中獲取的數(shù)據(jù), 可以設(shè)置緩存時(shí)間, 具體時(shí)間設(shè)置多少, 根據(jù)自己需求吧.
}
var_dump($rows); //打印出數(shù)據(jù)
//上面第一次運(yùn)行程序時(shí), 因?yàn)檫€沒有緩存數(shù)據(jù), 所以會(huì)讀取一次數(shù)據(jù)庫(kù), 當(dāng)再次訪問程序時(shí), 就直接重memcache獲取了.
?>
您可能感興趣的文章:
- PHP中的Memcache詳解
- php模塊memcache和memcached區(qū)別分析
- PHP memcache擴(kuò)展的三種安裝方法
- php擴(kuò)展memcached和memcache的安裝配置方法
- PHP操作Memcache實(shí)例介紹
- windows環(huán)境下php配置memcache的具體操作步驟
- centos系統(tǒng)為php安裝memcached擴(kuò)展步驟
- 基于php使用memcache存儲(chǔ)session的詳解
- PHP+memcache實(shí)現(xiàn)消息隊(duì)列案例分享
- PHP MemCached高級(jí)緩存配置圖文教程
- PHP數(shù)據(jù)庫(kù)操作二:memcache用法分析
相關(guān)文章
php學(xué)習(xí)筆記之mb_strstr的基本使用
這篇文章主要給大家介紹了關(guān)于php學(xué)習(xí)筆記之mb_strstr的基本使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2018-02-02PHP實(shí)現(xiàn)一維數(shù)組轉(zhuǎn)二維數(shù)組的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)一維數(shù)組轉(zhuǎn)二維數(shù)組的方法,實(shí)例分析了php操作數(shù)組的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02PHP實(shí)現(xiàn)通用alert函數(shù)的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)通用alert函數(shù)的方法,實(shí)例分析了php自定義alert函數(shù)實(shí)現(xiàn)提示信息的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-03-03PHP實(shí)現(xiàn)簡(jiǎn)單的模板引擎功能示例
這篇文章主要介紹了PHP實(shí)現(xiàn)簡(jiǎn)單的模板引擎功能,結(jié)合實(shí)例形式詳細(xì)分析了PHP實(shí)現(xiàn)模板引擎功能的模版類、編譯類、控制器類及模板文件等實(shí)現(xiàn)方法與相關(guān)操作技巧,需要的朋友可以參考下2017-09-09php實(shí)現(xiàn)數(shù)字轉(zhuǎn)億萬(wàn)單位的示例代碼
這篇文章主要為大家詳細(xì)介紹了php如何實(shí)現(xiàn)數(shù)字轉(zhuǎn)億萬(wàn)單位,文中的示例代碼講解詳細(xì),具有一定的借鑒價(jià)值,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-11-11使用PHP實(shí)現(xiàn)實(shí)時(shí)數(shù)據(jù)可視化功能的示例詳解
實(shí)時(shí)數(shù)據(jù)可視化功能,是指在Web應(yīng)用程序開發(fā)中,將服務(wù)器發(fā)送的實(shí)時(shí)數(shù)據(jù),本文將介紹如何使用PHP和前端框架實(shí)現(xiàn)實(shí)時(shí)數(shù)據(jù)可視化功能,需要的可以參考一下2023-07-07