Redis常用命令
PhpRedis是php的一个扩展,效率是相当高有链表排序功能,对创建内存级的模块业务关系很有用;以下是redis官方提供的命令使用技巧:
Redis::__construct构造函数
connect, open 链接redis服务
参数:
host: string,服务地址
port: int,端口号
timeout: float,链接时长 (可选, 默认为 0 ,不限链接时间)
注: 在redis.conf中也有时间,默认为300
pconnect, popen 不会主动关闭的链接
参考同上
setOption设置redis模式
getOption查看redis设置的模式
ping查看连接状态
get得到某个key的值(string值)
如果该key不存在,return false
set 写入key 和 value(string值)
如果写入成功,return ture
setex带生存时间的写入值
setnx 判断是否重复的,写入值
delete 删除指定key的值
返回已经删除key的个数(长整数)
ttl
得到一个key的生存时间
persist
移除生存时间到期的key
如果key到期 true 如果不到期 false
mset (redis版本1.1以上才可以用)
同时给多个key赋值
multi, exec, discard
进入或者退出事务模式
参数可选Redis::MULTI或Redis::PIPELINE. 默认是 Redis::MULTI
Redis::MULTI:将多个操作当成一个事务执行
Redis::PIPELINE:让(多条)执行命令简单的,更加快速的发送给服务器,但是没有任何原子性的保证
discard:删除一个事务
返回值
multi(),返回一个redis对象,并进入multi-mode模式,一旦进入multi-mode模式,以后调用的所有方法都会返回相同的对象,只到exec()方法被调用。
watch, unwatch(代码测试后,不能达到所说的效果)
监测一个key的值是否被其它的程序更改。如果这个key在watch 和 exec (方法)间被修改,这个 MULTI/EXEC 事务的执行将失败(return false)
unwatch 取消被这个程序监测的所有key
参数,一对key的列表
subscribe *
方法回调。注意,该方法可能在未来里发生改变
publish *
发表内容到某一个通道。注意,该方法可能在未来里发生改变
exists
判断key是否存在。存在 true 不在 false
incr, incrBy
key中的值进行自增1,如果填写了第二个参数,者自增第二个参数所填的值
decr, decrBy
做减法,使用方法同incr
getMultiple
传参
由key组成的数组
返回参数
如果key存在返回value,不存在返回false
List相关操作
lPush
在名称为key的list左边(头)添加一个值为value的元素
rPush
在名称为key的list右边(尾)添加一个值为value的元素
lPushx/rPushx
在名称为key的list左边(头)/右边(尾)添加一个值为value的元素,如果value已经存在,则不添加
lPop/rPop
输出名称为key的list左(头)起/右(尾)起的第一个元素,删除该元素
blPop/brPop
lpop命令的block版本。即当timeout为0时,若遇到名称为key i的list不存在或该list为空,则命令结束。如果timeout>0,则遇到上述情况时,等待timeout秒,如果问题没有解决,则对 keyi+1开始的list执行pop操作
lSize
返回名称为key的list有多少个元素
lIndex, lGet
返回名称为key的list中index位置的元素
lSet
给名称为key的list中index位置的元素赋值为value
lRange, lGetRange
返回名称为key的list中start至end之间的元素(end为 -1 ,返回所有)
lTrim, listTrim
截取名称为key的list,保留start至end之间的元素
lRem, lRemove
删除count个名称为key的list中值为value的元素。count为0,删除所有值为value的元素,count>0从头至尾删除count个值为value的元素,count<0从尾到头删除|count|个值为value的元素
lInsert
在名称为为key的list中,找到值为pivot 的value,并根据参数Redis::BEFORE | Redis::AFTER,来确定,newvalue 是放在 pivot 的前面,或者后面。如果key不存在,不会插入,如果 pivot不存在,return -1
rpoplpush
返回并删除名称为srckey的list的尾元素,并将该元素添加到名称为dstkey的list的头部
SET相关操作
sAdd
向名称为key的set中添加元素value,如果value存在,不写入,return false
sRem, sRemove
删除名称为key的set中的元素value
sMove
将value元素从名称为srckey的集合移到名称为dstkey的集合
sIsMember, sContains
名称为key的集合中查找是否有value元素,有ture 没有false
sCard, sSize
返回名称为key的set的元素个数
sPop
随机返回并删除名称为key的set中一个元素
sRandMember
随机返回名称为key的set中一个元素,不删除
sInter
求交集
sInterStore
求交集并将交集保存到output的集合
sUnion
求并集
sUnionStore
求并集并将并集保存到output的集合
sDiff
求差集
sDiffStore
求差集并将差集保存到output的集合
sMembers, sGetMembers
返回名称为key的set的所有元素
sort
排序,分页等
参数
'by' => 'some_pattern_*'
'limit' => array(0, 1)
'get' => 'some_other_pattern_*' or an array of patterns
'sort' => 'asc' or 'desc'
'alpha' => TRUE
'store' => 'external-key'
string相关操作
getSet
返回原来key中的值,并将value写入key
append
string,名称为key的string的值在后面加上value
getRange(方法不存在)
返回名称为key的string中start至end之间的字符
setRange(方法不存在)
改变key的string中start至end之间的字符为value
strlen
得到key的string的长度
getBit/setBit
返回2进制信息
zset(sorted set)相关操作
zAdd(key, score, member)
向名称为key的zset中添加元素member,score用于排序。如果该元素已经存在,则根据score更新该元素的顺序。
zRange(key, start, end,withscores)
返回名称为key的zset(元素已按score从小到大排序)中的index从start到end的所有元素
zDelete,zRem(key, member)
删除名称为key的zset中的元素member
zRevRange(key, start, end,withscores)
返回名称为key的zset(元素已按score从大到小排序)中的index从start到end的所有元素.withscores: 是否输出socre的值,默认false,不输出
zRangeByScore, zRevRangeByScore
返回名称为key的zset中score >= star且score <= end的所有元素
zCount
返回名称为key的zset中score >= star且score <= end的所有元素的个数
zRemRangeByScore, zDeleteRangeByScore
删除名称为key的zset中score >= star且score <= end的所有元素,返回删除个数
zSize, zCard
返回名称为key的zset的所有元素的个数
zScore
返回名称为key的zset中元素val2的score
zRank, zRevRank
返回名称为key的zset(元素已按score从小到大排序)中val元素的rank(即index,从0开始),若没有val元素,返回“null”。zRevRank 是从大到小排序
zIncrBy
如果在名称为key的zset中已经存在元素member,则该元素的score增加increment;否则向集合中添加该元素,其score的值为increment
zUnion/zInter
参数
keyOutput
arrayZSetKeys
arrayWeights
aggregateFunction Either "SUM", "MIN", or "MAX": defines the behaviour to use on duplicate entries during the zUnion.
对N个zset求并集和交集,并将最后的集合保存在dstkeyN中。对于集合中每一个元素的score,在进行AGGREGATE运算前,都要乘以对于 的WEIGHT参数。如果没有提供WEIGHT,默认为1。默认的AGGREGATE是SUM,即结果集合中元素的score是所有集合对应元素进行 SUM运算的值,而MIN和MAX是指,结果集合中元素的score是所有集合对应元素中最小值和最大值。
Hash相关操作
hSet
向名称为h的hash中添加元素key1—>hello
hGet
返回名称为h的hash中key1对应的value(hello)
hLen
返回名称为h的hash中元素个数
hDel
删除名称为h的hash中键为key1的域
hKeys
返回名称为key的hash中所有键
hVals
返回名称为h的hash中所有键对应的value
hGetAll
返回名称为h的hash中所有的键(field)及其对应的value
hExists
名称为h的hash中是否存在键名字为a的域
hIncrBy
将名称为h的hash中x的value增加2
hMset
向名称为key的hash中批量添加元素
hMGet
返回名称为h的hash中field1,field2对应的value
redis 相关操作
flushDB
清空当前数据库
flushAll
清空所有数据库
randomKey
随机返回key空间的一个key
select
选择一个数据库
move
转移一个key到另外一个数据库
rename, renameKey
给key重命名
renameNx
与remane类似,但是,如果重新命名的名字已经存在,不会替换成功
setTimeout, expire
设定一个key的活动时间(s)
expireAt
key存活到一个unix时间戳时间
keys, getKeys
返回满足给定pattern的所有key
dbSize
查看现在数据库有多少key
auth
密码认证
bgrewriteaof
使用aof来进行数据库持久化
slaveof
选择从服务器
save
将数据同步保存到磁盘
bgsave
将数据异步保存到磁盘
lastSave
返回上次成功将数据保存到磁盘的Unix时戳
info
返回redis的版本信息等详情
type
返回key的类型值
string: Redis::REDIS_STRING
set: Redis::REDIS_SET
list: Redis::REDIS_LIST
zset: Redis::REDIS_ZSET
hash: Redis::REDIS_HASH
other: Redis::REDIS_NOT_FOUND