php中Redis函數的用法總結

來源:互聯網
上載者:User
這篇文章主要介紹了php Redis函數用法,結合執行個體形式總結分析了php redis操作常用函數及具體使用方法,並附帶php串連redis單例類,需要的朋友可以參考下

本文執行個體總結了php Redis函數用法。分享給大家供大家參考,具體如下:

一直在拿PHP使用Redis,但是總感覺不牢靠,索性借這個時間空餘一氣呵成,
把PHP中所有操作到的Redis命令,幾乎全敲個遍,包括它的傳回值都是盯對過的,哪怕下回忘了也可以直接過來查嘛~大家也可以放心使用。

Tips:

對於:string, set , sort set , hash 的增,改操作,是同一個命令,但是把它當改操作時,及時成功傳回值依舊為0

對於:list結構來說,增刪改差自由一套方法。

<?php/*1.Connection*/  $redis = new Redis();  $redis->connect('127.0.0.1',6379,1);//短連結,本地host,連接埠為6379,超過1秒放棄連結  $redis->open('127.0.0.1',6379,1);//短連結(同上)  $redis->pconnect('127.0.0.1',6379,1);//長連結,本地host,連接埠為6379,超過1秒放棄連結  $redis->popen('127.0.0.1',6379,1);//長連結(同上)  $redis->auth('password');//登入驗證密碼,返回【true | false】  $redis->select(0);//選擇redis庫,0~15 共16個庫  $redis->close();//釋放資源  $redis->ping(); //檢查是否還再連結,[+pong]  $redis->ttl('key');//查看失效時間[-1 | timestamps]  $redis->persist('key');//移除失效時間[ 1 | 0]  $redis->sort('key',[$array]);//返回或儲存給定列表、集合、有序集合key中經過排序的元素,$array為參數limit等!【配合$array很強大】 [array|false]/*2.共性的運算歸類*/  $redis->expire('key',10);//設定失效時間[true | false]  $redis->move('key',15);//把當前庫中的key移動到15庫中[0|1]//string  $redis->strlen('key');//擷取當前key的長度  $redis->append('key','string');//把string追加到key現有的value中[追加後的個數]  $redis->incr('key');//自增1,如不存在key,賦值為1(只對整數有效,儲存以10進位64位,redis中為str)[new_num | false]  $redis->incrby('key',$num);//自增$num,不存在為賦值,值需為整數[new_num | false]  $redis->decr('key');//自減1,[new_num | false]  $redis->decrby('key',$num);//自減$num,[ new_num | false]  $redis->setex('key',10,'value');//key=value,有效期間為10秒[true]//list  $redis->llen('key');//返回列表key的長度,不存在key返回0, [ len | 0]//set  $redis->scard('key');//返回集合key的基數(集合中元素的數量)。[num | 0]  $redis->sMove('key1', 'key2', 'member');//移動,將member元素從key1集合移動到key2集合。[1 | 0]//Zset  $redis->zcard('key');//返回集合key的基數(集合中元素的數量)。[num | 0]  $redis->zcount('key',0,-1);//返回有序集key中,score值在min和max之間(預設包括score值等於min或max)的成員。[num | 0]//hash  $redis->hexists('key','field');//查看hash中是否存在field,[1 | 0]  $redis->hincrby('key','field',$int_num);//為雜湊表key中的域field的值加上量(+|-)num,[new_num | false]  $redis->hlen('key');//返回雜湊表key中域的數量。[ num | 0]/*3.Server*/  $redis->dbSize();//返回當前庫中的key的個數  $redis->flushAll();//清空整個redis[總true]  $redis->flushDB();//清空當前redis庫[總true]  $redis->save();//同步??把資料存放區到磁碟-dump.rdb[true]  $redis->bgsave();//非同步??把資料存放區到磁碟-dump.rdb[true]  $redis->info();//查詢當前redis的狀態 [verson:2.4.5....]  $redis->lastSave();//上次儲存時間key的時間[timestamp]  $redis->watch('key','keyn');//監視一個(或多個) key ,如果在事務執行之前這個(或這些) key 被其他命令所改動,那麼事務將被打斷 [true]  $redis->unwatch('key','keyn');//取消監視一個(或多個) key [true]  $redis->multi(Redis::MULTI);//開啟事務,事務塊內的多條命令會按照先後順序被放進一個隊列當中,最後由 EXEC 命令在一個原子時間內執行。  $redis->multi(Redis::PIPELINE);//開啟管道,事務塊內的多條命令會按照先後順序被放進一個隊列當中,最後由 EXEC 命令在一個原子時間內執行。  $redis->exec();//執行所有事務塊內的命令,;【事務塊內所有命令的傳回值,按命令執行的先後順序排列,當操作被打斷時,返回空值 false】/*4.String,索引值對,建立更新同操作*/  $redis->setOption(Redis::OPT_PREFIX,'hf_');//設定表首碼為hf_  $redis->set('key',1);//設定key=aa value=1 [true]  $redis->mset($arr);//設定一個或多個索引值[true]  $redis->setnx('key','value');//key=value,key存在返回false[|true]  $redis->get('key');//擷取key [value]  $redis->mget($arr);//(string|arr),返回所查詢鍵的值  $redis->del($key_arr);//(string|arr)刪除key,支援數組大量刪除【返回刪除個數】  $redis->delete($key_str,$key2,$key3);//刪除keys,[del_num]  $redis->getset('old_key','new_value');//先獲得key的值,然後重新賦值,[old_value | false]/*5.List棧的結構,注意表頭表尾,建立更新分開操作*/  $redis->lpush('key','value');//增,只能將一個值value插入到列表key的表頭,不存在就建立 [列表的長度 |false]  $redis->rpush('key','value');//增,只能將一個值value插入到列表key的表尾 [列表的長度 |false]  $redis->lInsert('key', Redis::AFTER, 'value', 'new_value');//增,將值value插入到列表key當中,位於值value之前或之後。[new_len | false]  $redis->lpushx('key','value');//增,只能將一個值value插入到列表key的表頭,不存在不建立 [列表的長度 |false]  $redis->rpushx('key','value');//增,只能將一個值value插入到列表key的表尾,不存在不建立 [列表的長度 |false]  $redis->lpop('key');//刪,移除並返回列表key的頭元素,[被刪元素 | false]  $redis->rpop('key');//刪,移除並返回列表key的尾元素,[被刪元素 | false]  $redis->lrem('key','value',0);//刪,根據參數count的值,移除列表中與參數value相等的元素count=(0|-n表頭向尾|+n表尾向頭移除n個value) [被移除的數量 | 0]  $redis->ltrim('key',start,end);//刪,列表修剪,保留(start,end)之間的值 [true|false]  $redis->lset('key',index,'new_v');//改,從表頭數,將列表key下標為第index的元素的值為new_v, [true | false]  $redis->lindex('key',index);//查,返回列表key中,下標為index的元素[value|false]  $redis->lrange('key',0,-1);//查,(start,stop|0,-1)返回列表key中指定區間內的元素,區間以位移量start和stop指定。[array|false]/*6.Set,沒有重複的member,建立更新同操作*/  $redis->sadd('key','value1','value2','valuen');//增,改,將一個或多個member元素加入到集合key當中,已經存在於集合的member元素將被忽略。[insert_num]  $redis->srem('key','value1','value2','valuen');//刪,移除集合key中的一個或多個member元素,不存在的member元素會被忽略 [del_num | false]  $redis->smembers('key');//查,返回集合key中的所有成員 [array | '']  $redis->sismember('key','member');//判斷member元素是否是集合key的成員 [1 | 0]  $redis->spop('key');//刪,移除並返回集合中的一個隨機元素 [member | false]  $redis->srandmember('key');//查,返回集合中的一個隨機元素 [member | false]  $redis->sinter('key1','key2','keyn');//查,返回所有給定集合的交集 [array | false]  $redis->sunion('key1','key2','keyn');//查,返回所有給定集合的並集 [array | false]  $redis->sdiff('key1','key2','keyn');//查,返回所有給定集合的差集 [array | false]/*7.Zset,沒有重複的member,有排序次序,建立更新同操作*/  $redis->zAdd('key',$score1,$member1,$scoreN,$memberN);//增,改,將一個或多個member元素及其score值加入到有序集key當中。[num | 0]  $redis->zrem('key','member1','membern');//刪,移除有序集key中的一個或多個成員,不存在的成員將被忽略。[del_num | 0]  $redis->zscore('key','member');//查,通過值反拿權 [num | null]  $redis->zrange('key',$start,$stop);//查,通過(score從小到大)【排序名次範圍】拿member值,返回有序集key中,【指定區間內】的成員 [array | null]  $redis->zrevrange('key',$start,$stop);//查,通過(score從大到小)【排序名次範圍】拿member值,返回有序集key中,【指定區間內】的成員 [array | null]  $redis->zrangebyscore('key',$min,$max[,$config]);//查,通過scroe權範圍拿member值,返回有序集key中,指定區間內的(從小到大排)成員[array | null]  $redis->zrevrangebyscore('key',$max,$min[,$config]);//查,通過scroe權範圍拿member值,返回有序集key中,指定區間內的(從大到小排)成員[array | null]  $redis->zrank('key','member');//查,通過member值查(score從小到大)排名結果中的【member排序名次】[order | null]  $redis->zrevrank('key','member');//查,通過member值查(score從大到小)排名結果中的【member排序名次】[order | null]  $redis->ZINTERSTORE();//交集  $redis->ZUNIONSTORE();//差集/*8.Hash,表結構,建立更新同操作*/  $redis->hset('key','field','value');//增,改,將雜湊表key中的域field的值設為value,不存在建立,存在就覆蓋【1 | 0】  $redis->hget('key','field');//查,取值【value|false】  $arr = array('one'=>1,2,3);$arr2 = array('one',0,1);  $redis->hmset('key',$arr);//增,改,設定多值$arr為(索引|關聯)數組,$arr[key]=field, [ true ]  $redis->hmget('key',$arr2);//查,擷取指定下標的field,[$arr | false]  $redis->hgetall('key');//查,返回雜湊表key中的所有域和值。[當key不存在時,返回一個空表]  $redis->hkeys('key');//查,返回雜湊表key中的所有域。[當key不存在時,返回一個空表]  $redis->hvals('key');//查,返回雜湊表key中的所有值。[當key不存在時,返回一個空表]  $redis->hdel('key',$arr2);//刪,刪除指定下標的field,不存在的域將被忽略,[num | false]?>

附:php 串連redis 資料庫單例類

<?phpclass RedisConnect{  /**   * Redis的ip   *   * @var string   */  const REDISHOSTNAME = "127.0.0.1";  /**   * Redis的port   *   * @var int   */  const REDISPORT = 6379;  /**   * Redis的逾時時間   *   * @var int   */  const REDISTIMEOUT = 0;  /**   * Redis的password   *   * @var unknown_type   */  const REDISPASSWORD = "ehualu";  /**   * Redis的DBname   *   * @var int   */  const REDISDBNAME = 12;  /**   * 類單例   *   * @var object   */  private static $instance;  /**   * Redis的串連控制代碼   *   * @var object   */  private $redis;  /**   * 私人化建構函式,防止類外執行個體化   *   * @param unknown_type $dbnumber   */  private function construct ()  {    // 連結資料庫    $this->redis = new Redis();    $this->redis->connect(self::REDISHOSTNAME, self::REDISPORT, self::REDISTIMEOUT);    $this->redis->auth(self::REDISPASSWORD);    $this->redis->select(self::REDISDBNAME);  }  /**   * 私人化複製函數,防止類外複製對象   */  private function clone ()  {}  /**   * 類的唯一公開靜態方法,擷取類單例的唯一入口   *   * @return object   */  public static function getRedisInstance ()  {    if (! (self::$instance instanceof self)) {      self::$instance = new self();    }    return self::$instance;  }  /**   * 擷取redis的串連執行個體   *   * @return Redis   */  public function getRedisConn ()  {    return $this->redis;  }  /**   * 需要在單例切換的時候做清理工作   */  public function destruct ()  {    self::$instance->redis->close();    self::$instance = NULL;  }}?>

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.