PHP对redis操作详解【转】
/1.Connection/
redis->connect('127.0.0.1',6379,1);//短链接,本地host,端口为6379,超过1秒放弃链接
redis->pconnect('127.0.0.1',6379,1);//长链接,本地host,端口为6379,超过1秒放弃链接
redis->auth('password');//登录验证密码,返回【true | false】
redis->close();//释放资源
redis->ttl('key');//查看失效时间[-1 | timestamps]
redis->sort('key',[array为参数limit等!【配合$array很强大】 [array|false]
/2.共性的运算归类/
redis->move('key',15);//把当前库中的key移动到15库中[0|1]
//string
redis->append('key','string');//把string追加到key现有的value中[追加后的个数]
redis->incrby('key',num,不存在为赋值,值需为整数[new_num | false]
redis->decrby('key',num,[ new_num | false]
redis->llen('key');//返回列表key的长度,不存在key返回0, [ len | 0]
//set
redis->sMove('key1', 'key2', 'member');//移动,将member元素从key1集合移动到key2集合。[1 | 0]
//Zset
redis->zcount('key',0,-1);//返回有序集key中,score值在min和max之间(默认包括score值等于min或max)的成员。[num | 0]
//hash
redis->hincrby('key','field',redis->hlen('key');//返回哈希表key中域的数量。[ num | 0]
/3.Server/
redis->flushAll();//清空整个redis[总true]
redis->save();//同步??把数据存储到磁盘-dump.rdb[true]
redis->info();//查询当前redis的状态 [verson:2.4.5....]
$redis->lastSave();//上次存储时间key的时间[timestamp]
redis->unwatch('key','keyn');//取消监视一个(或多个) key [true]
redis->multi(Redis::PIPELINE);//开启管道,事务块内的多条命令会按照先后顺序被放进一个队列当中,最后由 EXEC 命令在一个原子时间内执行。
$redis->exec();//执行所有事务块内的命令,;【事务块内所有命令的返回值,按命令执行的先后顺序排列,当操作被打断时,返回空值 false】
/4.String,键值对,创建更新同操作/
redis->set('key',1);//设置key=aa value=1 [true]
arr);//设置一个或多个键值[true]
redis->get('key');//获取key [value]
arr);//(string|arr),返回所查询键的值
key_arr);//(string|arr)删除key,支持数组批量删除【返回删除个数】
key_str,key3);//删除keys,[del_num]
$redis->getset('old_key','new_value');//先获得key的值,然后重新赋值,[old_value | false]
/5.List栈的结构,注意表头表尾,创建更新分开操作/
redis->rpush('key','value');//增,只能将一个值value插入到列表key的表尾 [列表的长度 |false]
redis->lpushx('key','value');//增,只能将一个值value插入到列表key的表头,不存在不创建 [列表的长度 |false]
redis->lpop('key');//删,移除并返回列表key的头元素,[被删元素 | false]
redis->lrem('key','value',0);//删,根据参数count的值,移除列表中与参数value相等的元素count=(0|-n表头向尾|+n表尾向头移除n个value) [被移除的数量 | 0]
redis->lset('key',index,'new_v');//改,从表头数,将列表key下标为第index的元素的值为new_v, [true | false]
redis->lrange('key',0,-1);//查,(start,stop|0,-1)返回列表key中指定区间内的元素,区间以偏移量start和stop指定。[array|false]
/6.Set,没有重复的member,创建更新同操作/
redis->srem('key','value1','value2','valuen');//删,移除集合key中的一个或多个member元素,不存在的member元素会被忽略 [del_num | false]
redis->sismember('key','member');//判断member元素是否是集合key的成员 [1 | 0]
redis->srandmember('key');//查,返回集合中的一个随机元素 [member | false]
redis->sunion('key1','key2','keyn');//查,返回所有给定集合的并集 [array | false]
$redis->sdiff('key1','key2','keyn');//查,返回所有给定集合的差集 [array | false]
/7.Zset,没有重复的member,有排序顺序,创建更新同操作/
score1,scoreN,redis->zrem('key','member1','membern');//删,移除有序集key中的一个或多个成员,不存在的成员将被忽略。[del_num | 0]
redis->zrange('key',stop);//查,通过(score从小到大)【排序名次范围】拿member值,返回有序集key中,【指定区间内】的成员 [array | null]
start,redis->zrangebyscore('key',max[,redis->zrevrangebyscore('key',min[,redis->zrank('key','member');//查,通过member值查(score从小到大)排名结果中的【member排序名次】[order | null]
redis->ZINTERSTORE();//交集
$redis->ZUNIONSTORE();//差集
/8.Hash,表结构,创建更新同操作/
redis->hget('key','field');//查,取值【value|false】
arr2 = array('one',0,1);
arr);//增,改,设置多值arr[key]=field, [ true ]
arr2);//查,获取指定下标的field,[redis->hgetall('key');//查,返回哈希表key中的所有域和值。[当key不存在时,返回一个空表]
redis->hvals('key');//查,返回哈希表key中的所有值。[当key不存在时,返回一个空表]
arr2);//删,删除指定下标的field,不存在的域将被忽略,[num | false]