Memcache 在PHP中的使用技巧
更新時間:2010年02月08日 09:55:06 作者:
Memcache 在PHP中的使用
add($key, $value, $expiry);
$key: 唯一標識, 用于區(qū)分寫入的數(shù)據(jù)
$value: 要寫入的數(shù)據(jù)
$expiry: 過期時間, 默認為永遠有效
用途: 將數(shù)據(jù)寫入到memcache中
get($key)
$key: 通過寫入時的$key獲取對應的數(shù)據(jù)
用途: 獲取memcache中的數(shù)據(jù)
replace($key, $value, $expiry)
該方法參數(shù)與add方法的參數(shù)相同
用途也很明顯就是替換數(shù)據(jù)
delete($key, $time = 0)
$key: 唯一標識
$time: 延遲時間
用途: 刪除memcache中存儲的數(shù)據(jù)
下面來看看具體用法:
add($key, $value, $expiry);
$key: 唯一標識, 用于區(qū)分寫入的數(shù)據(jù)
$value: 要寫入的數(shù)據(jù)
$expiry: 過期時間, 默認為永遠有效
用途: 將數(shù)據(jù)寫入到memcache中
get($key)
$key: 通過寫入時的$key獲取對應的數(shù)據(jù)
用途: 獲取memcache中的數(shù)據(jù)
replace($key, $value, $expiry)
該方法參數(shù)與add方法的參數(shù)相同
用途也很明顯就是替換數(shù)據(jù)
delete($key, $time = 0)
$key: 唯一標識
$time: 延遲時間
用途: 刪除memcache中存儲的數(shù)據(jù)
下面來看看具體用法:
代碼
<?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'); //替換內容為dataecho $m->get('mykey');//輸出 data
$m->delete('mykey'); //刪除echo $m->get('mykey'); //輸出 false 因為已經刪掉了哦..
?>
是不是很簡單.. 在實際應用中,通常會把數(shù)據(jù)庫查詢的結果集保存到 memcached 中
下次訪問時直接從 memcached 中獲取,而不再做數(shù)據(jù)庫查詢操作,這樣可以在很大程度上減輕數(shù)據(jù)庫的負擔。
通常會將 SQL 語句 md5() 之后的值作為唯一標識符 key。下邊是一個利用 memcached 來緩存數(shù)據(jù)庫查詢結果集的示例
代碼
<?php
//連接memcache
$m = new Memcache();
$m->connect('localhost', 11211);
//連接數(shù)據(jù)庫的我就不寫了.
$sql = 'SELECT * FROM users';
$key = md5($sql); //md5 SQL命令 作為 memcache的唯一標識符
$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);
//這里寫入重數(shù)據(jù)庫中獲取的數(shù)據(jù), 可以設置緩存時間, 具體時間設置多少, 根據(jù)自己需求吧.
}
var_dump($rows); //打印出數(shù)據(jù)
//上面第一次運行程序時, 因為還沒有緩存數(shù)據(jù), 所以會讀取一次數(shù)據(jù)庫, 當再次訪問程序時, 就直接重memcache獲取了.
?>
$key: 唯一標識, 用于區(qū)分寫入的數(shù)據(jù)
$value: 要寫入的數(shù)據(jù)
$expiry: 過期時間, 默認為永遠有效
用途: 將數(shù)據(jù)寫入到memcache中
get($key)
$key: 通過寫入時的$key獲取對應的數(shù)據(jù)
用途: 獲取memcache中的數(shù)據(jù)
replace($key, $value, $expiry)
該方法參數(shù)與add方法的參數(shù)相同
用途也很明顯就是替換數(shù)據(jù)
delete($key, $time = 0)
$key: 唯一標識
$time: 延遲時間
用途: 刪除memcache中存儲的數(shù)據(jù)
下面來看看具體用法:
add($key, $value, $expiry);
$key: 唯一標識, 用于區(qū)分寫入的數(shù)據(jù)
$value: 要寫入的數(shù)據(jù)
$expiry: 過期時間, 默認為永遠有效
用途: 將數(shù)據(jù)寫入到memcache中
get($key)
$key: 通過寫入時的$key獲取對應的數(shù)據(jù)
用途: 獲取memcache中的數(shù)據(jù)
replace($key, $value, $expiry)
該方法參數(shù)與add方法的參數(shù)相同
用途也很明顯就是替換數(shù)據(jù)
delete($key, $time = 0)
$key: 唯一標識
$time: 延遲時間
用途: 刪除memcache中存儲的數(shù)據(jù)
下面來看看具體用法:
代碼
復制代碼 代碼如下:
<?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'); //替換內容為dataecho $m->get('mykey');//輸出 data
$m->delete('mykey'); //刪除echo $m->get('mykey'); //輸出 false 因為已經刪掉了哦..
?>
是不是很簡單.. 在實際應用中,通常會把數(shù)據(jù)庫查詢的結果集保存到 memcached 中
下次訪問時直接從 memcached 中獲取,而不再做數(shù)據(jù)庫查詢操作,這樣可以在很大程度上減輕數(shù)據(jù)庫的負擔。
通常會將 SQL 語句 md5() 之后的值作為唯一標識符 key。下邊是一個利用 memcached 來緩存數(shù)據(jù)庫查詢結果集的示例
代碼
復制代碼 代碼如下:
<?php
//連接memcache
$m = new Memcache();
$m->connect('localhost', 11211);
//連接數(shù)據(jù)庫的我就不寫了.
$sql = 'SELECT * FROM users';
$key = md5($sql); //md5 SQL命令 作為 memcache的唯一標識符
$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);
//這里寫入重數(shù)據(jù)庫中獲取的數(shù)據(jù), 可以設置緩存時間, 具體時間設置多少, 根據(jù)自己需求吧.
}
var_dump($rows); //打印出數(shù)據(jù)
//上面第一次運行程序時, 因為還沒有緩存數(shù)據(jù), 所以會讀取一次數(shù)據(jù)庫, 當再次訪問程序時, 就直接重memcache獲取了.
?>
您可能感興趣的文章:
相關文章
PHP實現(xiàn)一維數(shù)組轉二維數(shù)組的方法
這篇文章主要介紹了PHP實現(xiàn)一維數(shù)組轉二維數(shù)組的方法,實例分析了php操作數(shù)組的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-02-02
使用PHP實現(xiàn)實時數(shù)據(jù)可視化功能的示例詳解
實時數(shù)據(jù)可視化功能,是指在Web應用程序開發(fā)中,將服務器發(fā)送的實時數(shù)據(jù),本文將介紹如何使用PHP和前端框架實現(xiàn)實時數(shù)據(jù)可視化功能,需要的可以參考一下2023-07-07

