Redis内容总结

2018-10-15  本文已影响0人  代码potty

Redis支持五种的数据类型

1、String
2、hash
3、list
4、set
5、sorted set

String数据类型

getrange key start end:返回key中字符串值的子字符
setrange key offset value:用value参数覆写给定Key所存储的字符串值,从offset开始
strlen:获取字符串长度
set key value:设置key value
get key:获取value
setex key value: 原子方式设置key value
setbit key offset value:设置字符串offset位上的值,为0或1


hash数据类型

hlen :获取长度
hget key field :获取值
hset key field value:单个添加
hmset key field1 value1 field2 value2 ..一起添加
hexists key field判断键是否存在
hdel key field删除key中的一个field
hkeys key 获取所有哈希表中的字段
hvals key 获取哈希表中所有的值
hsetnx key field value :当key中field不存在,设置这个字段的值


list双端链表数据类型

llen :输出列表长度
lpush:左输入
rpush:右输入
blpop key timeout:移除并获取列表第一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。(假如在指定时间内没有任何元素被弹出,则返回一个 nil 和等待时长。 反之,返回一个含有两个元素的列表,第一个元素是被弹出元素所属的 key ,第二个元素是被弹出元素的值。)

brpop key timeout:移除并获取列表最后一个元素, 如果列表没有元素会阻塞列表直到等待超时或发现可弹出元素为止。
lpop:简单移除并获取第一个元素
rpop:简单移除并获取最后一个元素
lindex key index:通过索引获取列表中的元素
lset key index value:通过索引设置列表元素的值
lrange key start stop:获取列表指定范围内的元素
ltrim key start stop:对列表进行修剪,只保留区间内的元素
rpoplpush source targe:将source链表最后一个元素弹出并且插入到targe链表中,最后返回这个元素的值


Set:String类型的无序集合,且不允许重复元素

sadd key value:添加元素
srem key member1 member2:移除集合中一个或多个成员

scard key :获取集合的成员数
smembers key :获取集合所有的成员
sismember key member:获取member是否是key中的

sdiff key1 key2:获取多个key的差集
sinter key1 key2:获取多个key的交集
sunion key1 key2:获取多个key的并集

smove sourve targe member:将sourve中的member移到targe中
spop key:移除并且返回集合中一个随机元素
srandmember key [count]:返回集合中一个或多个随机数


Sorted Set:有序集合

//与set类似,不同的是每个元素都会关联一个double类型的分数。
//redis正是通过分数来为集合中的成员进行从小到大的排序。

zadd key score1 member [score2 member2]:向有序集合添加一个或多个成员,或者更新已存在成员的分数
zrem key member [member..]移除有序集合中的一个或多个成员

/按照正常分数从低到高排序/
zrange key start stop :返回有序集合指定区间内的成员(默认从低到高排序)(start:0;end:-1代表查询这个Key所有的成员)
zrangebyscore key min max[withscores]:通过分数返回有序集合指定区间内的成员
zrank key member:返回该成员的索引

/rev代表的是reverse(反转)/
zrevrange key start stop[withscores]:返回有序集合指定区间内的成员,按照分数从高到低排序
zrevrangebyscore key max min[withscores]:返回有序集合指定分数区间内的成员,分数从高到低排序
zrevrank key member:返回有序集合中指定成员的排名,有序集合是按分数(从大到小)排序

zcard key :获取有序集合的成员数
zcount key min max:计算有序集合指定区间分数的成员数
zscore key member:返回该成员的分数值

zremrangebyrank key start stop:移除有序集合中给定排名区间的所有成员
zremrangebyscore key min max:移除给定分数区间的所有成员

zinterstore targe numkeys(交集的key个数) key1 key2..:计算给定一个或者多个有序集的交集并将结果存储到targe中
注意:此时交集结果成员的分数为多个有序集分数的总和
zunionstore targe numkeys key1 keys2:并集,与交集类似,最后的分数也是多个有序集分数的总和
注意:有序集合的redis没有提供多个集合差集的方法,这是跟无序集合的区别之一


redis发布订阅(redis用作消息队列)

1、subscribe channel[channel..] 订阅一个或者多个频道的信息
2、publish channel message 将消息发送到指定的频道
3、unsubscribe channel [channel ..] 退订一个或者多个频道的信息
4、psubscribe pattern [pattern ...] 订阅一个或者多个符合给定模式的频道
5、punsubscribe pattern [pattern ..] 退订一个或者多个符合给定模式的频道
6、pubsub subcommand [argument [argument]] 查看订阅与发布系统状态
参考链接:https://blog.csdn.net/qq_34212276/article/details/78455004

redis事务

redis事务可以一次执行多个命令,并且带有两个重要的保证:
1、redis使用multi开始一个事务,然后开始写redis命令,最后通过exec命令执行事务
exec命令执行事务的过程中有任意命令执行失败,其余命令依然被执行,之前执行的命令也不会回滚
2、事务执行过程中,其他客户端提交的命令请求不会插入到事务执行命令序列中

我们知道单个redis命令的执行是原子性的,但是redis事务不具备原子性机制,可以理解为一个打包批量执行的脚本

方法:
1、discard:取消事务,放弃执行事务块内所有命令
2、exec:执行所有事务块内的命令
3、multi:标记一个事务块的开始
4、unwatch:取消watch命令对所有Key的监视
5、watch key :监视一个或者多个key,如果在事务执行之前这个key被其他命令改动,那么事务将被打断

上一篇下一篇

猜你喜欢

热点阅读