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