本文實(shí)例講述了thinkPHP框架通過Redis實(shí)現(xiàn)增刪改查操作的方法。分享給大家供大家參考,具體如下:
一、概述
Redis是一個(gè)NoSQL數(shù)據(jù)庫,由于其數(shù)據(jù)類型的差異,所以要在MVC框架中實(shí)現(xiàn)CURD操作,比較繁鎖。事實(shí)上在ThinkPHP框架中,只能實(shí)現(xiàn)簡單的緩存應(yīng)用。而不像MongoDB那樣能夠?qū)崿F(xiàn)常見數(shù)據(jù)庫的CURD操作。本文章將通過擴(kuò)展的方式,實(shí)現(xiàn)Redis的CURD操作,這樣我們就可以像操作普通的Mysql數(shù)據(jù)庫那樣實(shí)現(xiàn)Redis的編程了。
二、實(shí)現(xiàn)過程
接下為將以ThinkPHP作為MVC開發(fā)框架,詳細(xì)介紹Redis的CURD操作。需要說明的是,在ThinkPHP中本身并不支持Redis開發(fā)環(huán)境,只支持使用Redis開發(fā)簡單的數(shù)據(jù)緩存功能。所以我們必須要通過擴(kuò)展功能,實(shí)現(xiàn)Redis的編程支持。為了方便讀者學(xué)習(xí),筆者臨時(shí)開發(fā)了相應(yīng)的模塊擴(kuò)展及數(shù)據(jù)庫擴(kuò)展。
解壓下載后的壓縮包,將得到DbRedis.class.php文件及RedisModel.class.php文件。將DbRedis.class.php文件復(fù)制到ThinkPHP/Extend/Driver/Db目錄;將RedisModel.class.php文件復(fù)制到ThinkPHP/Extend/Model目錄。然后在項(xiàng)目配置文件中加入Redis數(shù)據(jù)庫連接信息,如以下代碼所示。
'REDIS_HOST'=>'192.168.0.2',
'REDIS_PORT'=>6379,
'REDIS_AUTH'=>123456,
'REDIS_DB_PREFIX'=>'',
讀者可根據(jù)實(shí)際環(huán)境填寫即可。通過前面步驟,至此就完成了在ThinkPHP中進(jìn)行Redis開發(fā)的前期準(zhǔn)備,接下來將結(jié)合示例代碼,詳細(xì)演示Redis的CURD操作。
1、增加數(shù)據(jù)
這里的增加數(shù)據(jù)包括Redis五大數(shù)據(jù)類型的數(shù)據(jù)添加。由于篇幅所限,這里不再詳細(xì)介紹操作的實(shí)現(xiàn)原理,將通過代碼演示操作方式。如以下代碼所示。
?php
/**
* redis添加數(shù)據(jù)
* Enter description here ...
* @author Administrator
*
*/
class AddAction extends Action{
/**
* list類型
* Enter description here ...
*/
public function lists(){
$Redis=new RedisModel("list11");
//一次只能推送一條
echo $Redis->add("ceiba");
}
/**
* 字符串類型
* Enter description here ...
*/
public function string(){
$Redis=new RedisModel();
$data=array(
"str1"=>"ceiba", //一個(gè)key,對(duì)應(yīng)一個(gè)值
"str2"=>"李開湧",
"str3"=>"李明",
);
echo $Redis->type("string")->add($data);
}
/**
* HASH類型
* Enter description here ...
*/
public function hash(){
$Redis=new RedisModel("user:1");
$data=array(
"field1"=>"ceiba", //一個(gè)key,對(duì)應(yīng)一個(gè)值
"field2"=>"李開湧",
"field3"=>"李明",
);
//支持批量添加
echo $Redis->type("hash")->add($data);
}
/**
* 集合類型
* Enter description here ...
*/
public function sets(){
$Redis=new RedisModel("sets:1");
//一次只能推送一條
echo $Redis->type("sets")->add("ceiba");
}
/**
* 有序集合
* Enter description here ...
*/
public function zset(){
$Redis=new RedisModel("zset:1");
//支持批量添加
$data=array(
//排序=>值
"10"=>"ceiba",
"11"=>"李開湧",
"12"=>"李明"
);
echo $Redis->type("zset")->add($data);
}
}
?>
2、查詢數(shù)據(jù)
?php
// redis查詢數(shù)據(jù)
class IndexAction extends Action {
public function page(){
$this->display();
}
/**
* 列表類型,默認(rèn)類型
* Enter description here ...
*/
public function lists(){
//dump(C("REDIS_HOST"));
$Redis=new RedisModel("list1");
$field=array(
"nmae","age","pro"
);
$data=$Redis->field($field)->select();
dump($data);
//獲得隊(duì)列中的記錄總數(shù)
$count=$Redis->count();
dump($count);
}
/**
* 字符串類型
* Enter description here ...
*/
public function string(){
$Redis=new RedisModel();
//field 表示每個(gè)key名稱
$rows=$Redis->type("string")->field(array("str1","str2"))->select();
dump($rows);
}
/**
* HASH類型
* Enter description here ...
*/
public function hash(){
$Redis=new RedisModel("h9");
//默認(rèn)顯示所有HASH字段,可以通過field連慣操作限制
$rows=$Redis->type("hash")->field(array("field1"))->select();
dump($rows);
//統(tǒng)計(jì)總記錄
$count=$Redis->type("hash")->count();
dump($count);
}
/**
* 集合類型
* Enter description here ...
*/
public function sets(){
$Redis=new RedisModel();
$arr=array(
"s3","s4"
);
$rows=$Redis->type("sets")->field($arr)->where("sinterstore")->select();//求交集
dump($rows);
$rows=$Redis->type("sets")->field($arr)->where("sunion")->select();//求并集
dump($rows);
$rows=$Redis->type("sets")->field($arr)->where("sdiff")->select();//求差集
dump($rows);
$Redis=new RedisModel("s3");
$rows=$Redis->type("sets")->select(); //返回單個(gè)集合列表中的所有成員
dump($rows);
//統(tǒng)計(jì)記錄
$Redis=new RedisModel("s3");
$count=$Redis->type("sets")->count();
dump($count);
}
/**
* 有序集合
* Enter description here ...
*/
public function zset(){
$Redis=new RedisModel("z2");
//默認(rèn)顯示0到20
$data=$Redis->type("zset")->limit("0,-1")->select();
dump($data);
//使用zRevRange顯示數(shù)據(jù),數(shù)組第2個(gè)參數(shù)為true時(shí)顯示排序號(hào)
$data=$Redis->type("zset")->limit("0,-1")->order(array("zRevRange",true))->select();
dump($data);
//不設(shè)置limit時(shí),將統(tǒng)計(jì)所有記錄
$count=$Redis->type("zset")->limit("0,1")->count();
dump($count);
}
}
3、刪除數(shù)據(jù)
?php
/**
* Redis刪除數(shù)據(jù)
* Enter description here ...
* @author Administrator
*
*/
class DeleteAction extends Action{
/**
* list類型
* Enter description here ...
*/
public function lists(){
$Redis=new RedisModel("mylist");
//根據(jù)索引號(hào),刪除指定的list元素
echo $Redis->where(3)->delete();
//ltrim區(qū)間批量刪除,保留4~5之間的記錄
echo $Redis->type("list")->where(array("4","5"))->delete("ltrim");
//lpop單條順序彈出
echo $Redis->type("list")->delete("lpop");
}
/**
* 字符串類型
* Enter description here ...
*/
public function string(){
$Redis=new RedisModel();
//直接刪除key,這各方式適用于所有數(shù)據(jù)類型
echo $Redis->type("string")->field(array("str1","str2"))->delete();
}
/**
* HASH類型
* Enter description here ...
*/
public function hash(){
$Redis=new RedisModel("user:1");
//刪除指定hash中的指定字段(field),不支持批量刪除
echo $Redis->type("hash")->where("field1")->delete();
}
/**
* 集合類型
* Enter description here ...
*/
public function sets(){
$Redis=new RedisModel("s1");
//刪除sets:1集合中名為age的value
echo $Redis->type("sets")->where("age")->delete();
}
/**
* 有序集合
* Enter description here ...
*/
public function zset(){
$Redis=new RedisModel("z1");
//根據(jù)集合元素value進(jìn)行刪除
echo $Redis->type("zset")->where("two")->delete();
//根據(jù)排序號(hào)進(jìn)行區(qū)間批量刪除,保留2~3之間的記錄
echo $Redis->type("zset")->where(array("1","4"))->delete("zremRangeByScore");
//根據(jù)索引號(hào)進(jìn)行區(qū)間批量刪除,保留2~3之間的記錄
echo $Redis->type("zset")->where(array("1","3"))->delete("zRemRangeByRank");
}
}
?>
更多關(guān)于thinkPHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《ThinkPHP入門教程》、《thinkPHP模板操作技巧總結(jié)》、《ThinkPHP常用方法總結(jié)》、《codeigniter入門教程》、《CI(CodeIgniter)框架進(jìn)階教程》、《Zend FrameWork框架入門教程》及《PHP模板技術(shù)總結(jié)》。
希望本文所述對(duì)大家基于ThinkPHP框架的PHP程序設(shè)計(jì)有所幫助。
您可能感興趣的文章:- PHP Redis擴(kuò)展無法加載的問題解決方法
- PHP+redis實(shí)現(xiàn)的限制搶購防止商品超發(fā)功能詳解
- PHP商品秒殺問題解決方案實(shí)例詳解【mysql與redis】
- PHP+Redis鏈表解決高并發(fā)下商品超賣問題(實(shí)現(xiàn)原理及步驟)