Memcache 在PHP中的提示

來源:互聯網
上載者:User

add($key, $value, $expiry);
$key: 唯一標識, 用於區分寫入的資料
$value: 要寫入的資料
$expiry: 到期時間, 預設為永遠有效
用途: 將資料寫入到memcache中

get($key)
$key: 通過寫入時的$key擷取對應的資料
用途: 擷取memcache中的資料

replace($key, $value, $expiry)
該方法參數與add方法的參數相同
用途也很明顯就是替換資料

delete($key, $time = 0)
$key: 唯一標識
$time: 延遲時間
用途: 刪除memcache中儲存的資料

下面來看看具體用法:
add($key, $value, $expiry);
$key: 唯一標識, 用於區分寫入的資料
$value: 要寫入的資料
$expiry: 到期時間, 預設為永遠有效
用途: 將資料寫入到memcache中

get($key)
$key: 通過寫入時的$key擷取對應的資料
用途: 擷取memcache中的資料

replace($key, $value, $expiry)
該方法參數與add方法的參數相同
用途也很明顯就是替換資料

delete($key, $time = 0)
$key: 唯一標識
$time: 延遲時間
用途: 刪除memcache中儲存的資料

下面來看看具體用法:

代碼 複製代碼 代碼如下:<?php
$m = new Memcache();
$m->connect('localhost', 11211);
$data = 'content'; //需要緩衝的資料
$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 因為已經刪掉了哦..
?>

是不是很簡單.. 在實際應用中,通常會把資料庫查詢的結果集儲存到 memcached 中
下次訪問時直接從 memcached 中擷取,而不再做資料庫查詢操作,這樣可以在很大程度上減輕資料庫的負擔。
通常會將 SQL 陳述式 md5() 之後的值作為唯一識別碼 key。下邊是一個利用 memcached 來快取資料庫查詢結果集的樣本
代碼 複製代碼 代碼如下:<?php
//串連memcache
$m = new Memcache();
$m->connect('localhost', 11211);
//串連資料庫的我就不寫了.
$sql = 'SELECT * FROM users';
$key = md5($sql); //md5 SQL命令 作為 memcache的唯一識別碼
$rows = $m->get($key); //先重memcache擷取資料
if (!$rows) {
//如果$rows為false那麼就是沒有資料咯, 那麼就寫入資料
$res = mysql_query($sql);
$rows = array();
while ($row = mysql_fetch_array($res)) {
$rows[] = $row;
}
$m->add($key, $rows);
//這裡寫入重資料庫中擷取的資料, 可以設定緩衝時間, 具體時間設定多少, 根據自己需求吧.
}
var_dump($rows); //列印出資料
//上面第一次運行程式時, 因為還沒有快取資料, 所以會讀取一次資料庫, 當再次訪問程式時, 就直接重memcache擷取了.
?>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.