溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在thinkPHP框架中使用Redis實現(xiàn)一個增刪改查操作

發(fā)布時間:2021-02-08 15:04:41 來源:億速云 閱讀:230 作者:Leah 欄目:開發(fā)技術

如何在thinkPHP框架中使用Redis實現(xiàn)一個增刪改查操作?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個問題。

一、概述

Redis是一個NoSQL數(shù)據(jù)庫,由于其數(shù)據(jù)類型的差異,所以要在MVC框架中實現(xiàn)CURD操作,比較繁鎖。事實上在ThinkPHP框架中,只能實現(xiàn)簡單的緩存應用。而不像MongoDB那樣能夠實現(xiàn)常見數(shù)據(jù)庫的CURD操作。本文章將通過擴展的方式,實現(xiàn)Redis的CURD操作,這樣我們就可以像操作普通的Mysql數(shù)據(jù)庫那樣實現(xiàn)Redis的編程了。

二、實現(xiàn)過程

接下為將以ThinkPHP作為MVC開發(fā)框架,詳細介紹Redis的CURD操作。需要說明的是,在ThinkPHP中本身并不支持Redis開發(fā)環(huán)境,只支持使用Redis開發(fā)簡單的數(shù)據(jù)緩存功能。所以我們必須要通過擴展功能,實現(xiàn)Redis的編程支持。為了方便讀者學習,筆者臨時開發(fā)了相應的模塊擴展及數(shù)據(jù)庫擴展。

解壓下載后的壓縮包,將得到DbRedis.class.php文件及RedisModel.class.php文件。將DbRedis.class.php文件復制到ThinkPHP/Extend/Driver/Db目錄;將RedisModel.class.php文件復制到ThinkPHP/Extend/Model目錄。然后在項目配置文件中加入Redis數(shù)據(jù)庫連接信息,如以下代碼所示。

'REDIS_HOST'=>'192.168.0.2',
'REDIS_PORT'=>6379,
'REDIS_AUTH'=>123456,
'REDIS_DB_PREFIX'=>'',

讀者可根據(jù)實際環(huán)境填寫即可。通過前面步驟,至此就完成了在ThinkPHP中進行Redis開發(fā)的前期準備,接下來將結合示例代碼,詳細演示Redis的CURD操作。

1、增加數(shù)據(jù)

這里的增加數(shù)據(jù)包括Redis五大數(shù)據(jù)類型的數(shù)據(jù)添加。由于篇幅所限,這里不再詳細介紹操作的實現(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", //一個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、查詢數(shù)據(jù)

<?php
// redis查詢數(shù)據(jù)
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);
    //獲得隊列中的記錄總數(shù)
    $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);
      //統(tǒng)計總記錄
      $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);
     //統(tǒng)計記錄
     $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顯示數(shù)據(jù),數(shù)組第2個參數(shù)為true時顯示排序號
     $data=$Redis->type("zset")->limit("0,-1")->order(array("zRevRange",true))->select();
    dump($data);
    //不設置limit時,將統(tǒng)計所有記錄
    $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ù)索引號,刪除指定的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進行刪除
    echo $Redis->type("zset")->where("two")->delete();
    //根據(jù)排序號進行區(qū)間批量刪除,保留2~3之間的記錄
    echo $Redis->type("zset")->where(array("1","4"))->delete("zremRangeByScore");
    //根據(jù)索引號進行區(qū)間批量刪除,保留2~3之間的記錄
    echo $Redis->type("zset")->where(array("1","3"))->delete("zRemRangeByRank");
  }
}
?>

看完上述內容,你們掌握如何在thinkPHP框架中使用Redis實現(xiàn)一個增刪改查操作的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。

AI