连接本地的 Redis 服务

<?php
	$redis =new Redis();
	$redis->connect('127.0.0.1',6379);
	$redis->auth('123456');
	$redis->select(2);  // 进入2号库
	$redis->set("name","Connection to server sucessfully");// 设置 redis 字符串数据
	echo $redis->get("name");// 获取存储的数据并输出

五种数据类型常用操作

  1. 字符串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]
    $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]
    $redis->keys('*'); // 遍历所有的键名
    
  2. 列表List栈的结构,注意表头表尾,创建更新分开操作
    $redis->lpush('key','value'); // 增,将value值插入列表表头。
    $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->brpop('key',)// 删,移除并返回列表key的尾元素。第二个参数表示等待时长,超过时长返回nil。
    $redis->blpop('key',1); // 删,移除并返回列表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]
    $redis->llen('key');// 返回列表key的长度,不存在key返回0, [ len | 0]
    
  3. 集合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]
    $redis->scard('key');// 返回集合key的基数(集合中元素的数量)。[num | 0]
    $redis->sMove('key1','key2','member');// 移动,将member元素从key1集合移动到key2集合。[1 | 0]
    
  4. 有序集合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();// 一个或多个有序集的并集
    $redis->zcard('key');// 返回集合key的基数(集合中元素的数量)。[num | 0]
    $redis->zcount('key',0,-1);// 返回有序集key中,score值在min和max之间(默认包括score值等于min或max)的成员。[num | 0]
    $redis->Zincrby('key',1,'member'); // member元素的score值 自增减(+-)num
    
  5. 哈希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]
    $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]
    

其他操作

// 1.连接
$redis =newRedis();
$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~255 共256个库
$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->set($key, $value, ['nx', 'ex' => $ttl])  // 做逻辑锁
$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】
$redis->discard()  // 取消事务
$redis->exists('key');  // 判断key是否存在
$redis->expire('key',10);// 设置失效时间[true | false]
$redis->move('key',15);// 把当前库中的key移动到15库中[0|1]