redis典型例子

本文实例总结了php Redis函数用法。分享给大家供大家参考,具体如下:

一直在拿PHP使用Redis,但是总感觉不牢靠,索性借这个时间空余一气呵成,
把PHP中所有操作到的Redis命令,几乎全敲个遍,包括它的返回值都是盯对过的,哪怕下回忘了也可以直接过来查嘛~大家也可以放心使用。

测试环境:    PHP:5.5     Redis:2.4.6

Tips:

对于:string, set , sort set , hash 的增,改操作,是同一个命令,但是把它当改操作时,及时成功返回值依旧为0

对于:list结构来说,增删改差自由一套方法。

[php]  view plain  copy
  1. <?php  
  2. /*1.Connection*/  
  3.   $redis = new Redis();  
  4.   $redis->connect('127.0.0.1',6379,1);//短链接,本地host,端口为6379,超过1秒放弃链接  
  5.   $redis->open('127.0.0.1',6379,1);//短链接(同上)  
  6.   $redis->pconnect('127.0.0.1',6379,1);//长链接,本地host,端口为6379,超过1秒放弃链接  
  7.   $redis->popen('127.0.0.1',6379,1);//长链接(同上)  
  8.   $redis->auth('password');//登录验证密码,返回【true | false】  
  9.   $redis->select(0);//选择redis库,0~15 共16个库  
  10.   $redis->close();//释放资源  
  11.   $redis->ping(); //检查是否还再链接,[+pong]  
  12.   $redis->ttl('key');//查看失效时间[-1 | timestamps]  
  13.   $redis->persist('key');//移除失效时间[ 1 | 0]  
  14.   $redis->sort('key',[$array]);//返回或保存给定列表、集合、有序集合key中经过排序的元素,$array为参数limit等!【配合$array很强大】 [array|false]  
  15. /*2.共性的运算归类*/  
  16.   $redis->expire('key',10);//设置失效时间[true | false]  
  17.   $redis->move('key',15);//把当前库中的key移动到15库中[0|1]  
  18. //string  
  19.   $redis->strlen('key');//获取当前key的长度  
  20.   $redis->append('key','string');//把string追加到key现有的value中[追加后的个数]  
  21.   $redis->incr('key');//自增1,如不存在key,赋值为1(只对整数有效,存储以10进制64位,redis中为str)[new_num | false]  
  22.   $redis->incrby('key',$num);//自增$num,不存在为赋值,值需为整数[new_num | false]  
  23.   $redis->decr('key');//自减1,[new_num | false]  
  24.   $redis->decrby('key',$num);//自减$num,[ new_num | false]  
  25.   $redis->setex('key',10,'value');//key=value,有效期为10秒[true]  
  26. //list  
  27.   $redis->llen('key');//返回列表key的长度,不存在key返回0, [ len | 0]  
  28. //set  
  29.   $redis->scard('key');//返回集合key的基数(集合中元素的数量)。[num | 0]  
  30.   $redis->sMove('key1''key2''member');//移动,将member元素从key1集合移动到key2集合。[1 | 0]  
  31. //Zset  
  32.   $redis->zcard('key');//返回集合key的基数(集合中元素的数量)。[num | 0]  
  33.   $redis->zcount('key',0,-1);//返回有序集key中,score值在min和max之间(默认包括score值等于min或max)的成员。[num | 0]  
  34. //hash  
  35.   $redis->hexists('key','field');//查看hash中是否存在field,[1 | 0]  
  36.   $redis->hincrby('key','field',$int_num);//为哈希表key中的域field的值加上量(+|-)num,[new_num | false]  
  37.   $redis->hlen('key');//返回哈希表key中域的数量。[ num | 0]  
  38. /*3.Server*/  
  39.   $redis->dbSize();//返回当前库中的key的个数  
  40.   $redis->flushAll();//清空整个redis[总true]  
  41.   $redis->flushDB();//清空当前redis库[总true]  
  42.   $redis->save();//同步??把数据存储到磁盘-dump.rdb[true]  
  43.   $redis->bgsave();//异步??把数据存储到磁盘-dump.rdb[true]  
  44.   $redis->info();//查询当前redis的状态 [verson:2.4.5....]  
  45.   $redis->lastSave();//上次存储时间key的时间[timestamp]  
  46.   $redis->watch('key','keyn');//监视一个(或多个) key ,如果在事务执行之前这个(或这些) key 被其他命令所改动,那么事务将被打断 [true]  
  47.   $redis->unwatch('key','keyn');//取消监视一个(或多个) key [true]  
  48.   $redis->multi(Redis::MULTI);//开启事务,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。  
  49.   $redis->multi(Redis::PIPELINE);//开启管道,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。  
  50.   $redis->exec();//执行所有事务块内的命令,;【事务块内所有命令的返回值,按命令执行的先后顺序排列,当操作被打断时,返回空值 false】  
  51. /*4.String,键值对,创建更新同操作*/  
  52.   $redis->setOption(Redis::OPT_PREFIX,'hf_');//设置表前缀为hf_  
  53.   $redis->set('key',1);//设置key=aa value=1 [true]  
  54.   $redis->mset($arr);//设置一个或多个键值[true]  
  55.   $redis->setnx('key','value');//key=value,key存在返回false[|true]  
  56.   $redis->get('key');//获取key [value]  
  57.   $redis->mget($arr);//(string|arr),返回所查询键的值  
  58.   $redis->del($key_arr);//(string|arr)删除key,支持数组批量删除【返回删除个数】  
  59.   $redis->delete($key_str,$key2,$key3);//删除keys,[del_num]  
  60.   $redis->getset('old_key','new_value');//先获得key的值,然后重新赋值,[old_value | false]  
  61. /*5.List栈的结构,注意表头表尾,创建更新分开操作*/  
  62.   $redis->lpush('key','value');//增,只能将一个值value插入到列表key的表头,不存在就创建 [列表的长度 |false]  
  63.   $redis->rpush('key','value');//增,只能将一个值value插入到列表key的表尾 [列表的长度 |false]  
  64.   $redis->lInsert('key', Redis::AFTER, 'value''new_value');//增,将值value插入到列表key当中,位于值value之前或之后。[new_len | false]  
  65.   $redis->lpushx('key','value');//增,只能将一个值value插入到列表key的表头,不存在不创建 [列表的长度 |false]  
  66.   $redis->rpushx('key','value');//增,只能将一个值value插入到列表key的表尾,不存在不创建 [列表的长度 |false]  
  67.   $redis->lpop('key');//删,移除并返回列表key的头元素,[被删元素 | false]  
  68.   $redis->rpop('key');//删,移除并返回列表key的尾元素,[被删元素 | false]  
  69.   $redis->lrem('key','value',0);//删,根据参数count的值,移除列表中与参数value相等的元素count=(0|-n表头向尾|+n表尾向头移除n个value) [被移除的数量 | 0]  
  70.   $redis->ltrim('key',start,end);//删,列表修剪,保留(start,end)之间的值 [true|false]  
  71.   $redis->lset('key',index,'new_v');//改,从表头数,将列表key下标为第index的元素的值为new_v, [true | false]  
  72.   $redis->lindex('key',index);//查,返回列表key中,下标为index的元素[value|false]  
  73.   $redis->lrange('key',0,-1);//查,(start,stop|0,-1)返回列表key中指定区间内的元素,区间以偏移量start和stop指定。[array|false]  
  74. /*6.Set,没有重复的member,创建更新同操作*/  
  75.   $redis->sadd('key','value1','value2','valuen');//增,改,将一个或多个member元素加入到集合key当中,已经存在于集合的member元素将被忽略。[insert_num]  
  76.   $redis->srem('key','value1','value2','valuen');//删,移除集合key中的一个或多个member元素,不存在的member元素会被忽略 [del_num | false]  
  77.   $redis->smembers('key');//查,返回集合key中的所有成员 [array | '']  
  78.   $redis->sismember('key','member');//判断member元素是否是集合key的成员 [1 | 0]  
  79.   $redis->spop('key');//删,移除并返回集合中的一个随机元素 [member | false]  
  80.   $redis->srandmember('key');//查,返回集合中的一个随机元素 [member | false]  
  81.   $redis->sinter('key1','key2','keyn');//查,返回所有给定集合的交集 [array | false]  
  82.   $redis->sunion('key1','key2','keyn');//查,返回所有给定集合的并集 [array | false]  
  83.   $redis->sdiff('key1','key2','keyn');//查,返回所有给定集合的差集 [array | false]  
  84. /*7.Zset,没有重复的member,有排序顺序,创建更新同操作*/  
  85.   $redis->zAdd('key',$score1,$member1,$scoreN,$memberN);//增,改,将一个或多个member元素及其score值加入到有序集key当中。[num | 0]  
  86.   $redis->zrem('key','member1','membern');//删,移除有序集key中的一个或多个成员,不存在的成员将被忽略。[del_num | 0]  
  87.   $redis->zscore('key','member');//查,通过值反拿权 [num | null]  
  88.   $redis->zrange('key',$start,$stop);//查,通过(score从小到大)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]  
  89.   $redis->zrevrange('key',$start,$stop);//查,通过(score从大到小)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]  
  90.   $redis->zrangebyscore('key',$min,$max[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从小到大排)成员[array | null]  
  91.   $redis->zrevrangebyscore('key',$max,$min[,$config]);//查,通过scroe权范围拿member值,返回有序集key中,指定区间内的(从大到小排)成员[array | null]  
  92.   $redis->zrank('key','member');//查,通过member值查(score从小到大)排名结果中的【member排序名次】[order | null]  
  93.   $redis->zrevrank('key','member');//查,通过member值查(score从大到小)排名结果中的【member排序名次】[order | null]  
  94.   $redis->ZINTERSTORE();//交集  
  95.   $redis->ZUNIONSTORE();//差集  
  96. /*8.Hash,表结构,创建更新同操作*/  
  97.   $redis->hset('key','field','value');//增,改,将哈希表key中的域field的值设为value,不存在创建,存在就覆盖【1 | 0】  
  98.   $redis->hget('key','field');//查,取值【value|false】  
  99.   $arr = array('one'=>1,2,3);$arr2 = array('one',0,1);  
  100.   $redis->hmset('key',$arr);//增,改,设置多值$arr为(索引|关联)数组,$arr[key]=field, [ true ]  
  101.   $redis->hmget('key',$arr2);//查,获取指定下标的field,[$arr | false]  
  102.   $redis->hgetall('key');//查,返回哈希表key中的所有域和值。[当key不存在时,返回一个空表]  
  103.   $redis->hkeys('key');//查,返回哈希表key中的所有域。[当key不存在时,返回一个空表]  
  104.   $redis->hvals('key');//查,返回哈希表key中的所有值。[当key不存在时,返回一个空表]  
  105.   $redis->hdel('key',$arr2);//删,删除指定下标的field,不存在的域将被忽略,[num | false]  
  106. ?>  

附:php 连接redis 数据库单例类

[php]  view plain  copy
  1. <?php  
  2. class RedisConnect  
  3. {  
  4.   /** 
  5.    * Redis的ip 
  6.    * 
  7.    * @var string 
  8.    */  
  9.   const REDISHOSTNAME = "127.0.0.1";  
  10.   /** 
  11.    * Redis的port 
  12.    * 
  13.    * @var int 
  14.    */  
  15.   const REDISPORT = 6379;  
  16.   /** 
  17.    * Redis的超时时间 
  18.    * 
  19.    * @var int 
  20.    */  
  21.   const REDISTIMEOUT = 0;  
  22.   /** 
  23.    * Redis的password 
  24.    * 
  25.    * @var unknown_type 
  26.    */  
  27.   const REDISPASSWORD = "ehualu";  
  28.   /** 
  29.    * Redis的DBname 
  30.    * 
  31.    * @var int 
  32.    */  
  33.   const REDISDBNAME = 12;  
  34.   /** 
  35.    * 类单例 
  36.    * 
  37.    * @var object 
  38.    */  
  39.   private static $instance;  
  40.   /** 
  41.    * Redis的连接句柄 
  42.    * 
  43.    * @var object 
  44.    */  
  45.   private $redis;  
  46.   /** 
  47.    * 私有化构造函数,防止类外实例化 
  48.    * 
  49.    * @param unknown_type $dbnumber 
  50.    */  
  51.   private function __construct ()  
  52.   {  
  53.     // 链接数据库  
  54.     $this->redis = new Redis();  
  55.     $this->redis->connect(self::REDISHOSTNAME, self::REDISPORT, self::REDISTIMEOUT);  
  56.     $this->redis->auth(self::REDISPASSWORD);  
  57.     $this->redis->select(self::REDISDBNAME);  
  58.   }  
  59.   /** 
  60.    * 私有化克隆函数,防止类外克隆对象 
  61.    */  
  62.   private function __clone ()  
  63.   {}  
  64.   /** 
  65.    * 类的唯一公开静态方法,获取类单例的唯一入口 
  66.    * 
  67.    * @return object 
  68.    */  
  69.   public static function getRedisInstance ()  
  70.   {  
  71.     if (! (self::$instance instanceof self)) {  
  72.       self::$instance = new self();  
  73.     }  
  74.     return self::$instance;  
  75.   }  
  76.   /** 
  77.    * 获取redis的连接实例 
  78.    * 
  79.    * @return Redis 
  80.    */  
  81.   public function getRedisConn ()  
  82.   {  
  83.     return $this->redis;  
  84.   }  
  85.   /** 
  86.    * 需要在单例切换的时候做清理工作 
  87.    */  
  88.   public function __destruct ()  
  89.   {  
  90.     self::$instance->redis->close();  
  91.     self::$instance = NULL;  
  92.   }  
  93. }  
  94. ?>  

猜你喜欢

转载自blog.csdn.net/tiaozhanji_xian/article/details/80528161
今日推荐