這篇文章主要介紹了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; }}?>