redis-vaule类型
数据库中有mysql,redis等,我们今天聊一聊redis
- StringByte
- List
- Hash
- Set
- Sorted_set
StringByte
String字符串
对于String可以有哪些操作
代码语言:javascript复制set k1 aabb
get k1
还可以help set查看跟哪些参数
代码语言:javascript复制set k1 hello
set k1 ooxx nx #这个nx表示当k1这个key不存在时才去设置,应用场景比如分布式锁
get k1
这个nx比如一堆连接去创建某个Key,但是只有一个会返回成功,其他都会失败
代码语言:javascript复制set k2 hello xx #xx表示只能更新,就是说这个Key是预先存在的
mset 这个命令后面可以跟多个key-value
mget 对应多个key取出
更多的可以直接 help@string来查看更多命令
比如APPEND GETRANGE
STRLEN k1 取长度
type命令 可以查看key的value类型,属于哪个分组就是哪个类型
OBJECT 命令可以查看key的encoding,查看更多关于object可以 输入
代码语言:javascript复制object help
在key的结构里除了存储key的名字还存储了vaule的type以及encoding,客户端如java代码对某些key操作时,比如类型不匹配可以直接报错
数值
INCR命令,redis是可以对数值进行操作的
小实验
继续跟着实验
代码语言:javascript复制set k3 a
strlen k3 #长度为1
APPEND k3 中
strlen k3 #长度为4,为什么?因为二进制安全,当前用的xshell连接的字符集是utf-8,一个中占3个字节
二进制安全
使用的是字节流,是二进制安全的。所以比如java代码在设置和取值时就要约定好编码解码的字符集。
加了参数raw后它就会按照utf-8进行结果输出
bitmap
命令 setbit
setbit是对位进行操作置1,取值是二进制对应的ASCII码
命令bitpos,找的是二进制字符流指定的位置,结果是二进制的位的位置
命令bitcount
统计key的字节里包含1的个数
命令bitop
对两个Key进行按位与或非异或
应用场景比如:
- 统计某个网站的用户一年365天某个随即时间段的登录天数
- 比如京东是我们在开发,现在有个需求双十一要给用户送礼物,京东总共有2亿用户要准备多少礼品呢?这就涉及到到底有多少活跃用户
string总结
List
命令help @list查看关于list类型的命令帮助
LRANGE查看
描述栈
lpush lpop
rpush rpop
后进先出,同向命令
描述队列,反向命令
lpush rpop
LRANGE
list也是有正负向索引的
LINDEX 根据索引取
LSET根据索引更新
LINSERT
LREM移除元素,中间的count有正数负数和零,正数就是从左
LLEN统计长度
BLPOP,BRPOP阻塞的,一直等着有元素了就pop出来
模拟一下就是我开redis3个客户端,第一个和第二个使用blpop ooxx 0,这时候2个都阻塞着了,第三个客户端使用rpush ooxx hello,第一个拿到元素,第二个还是阻塞,第三个客户端重复压入数据,第二个拿到元素。
LTRIM去除索引2端的数据
list总结
hash
help @hash
命令基本上可以理解为在string命令前加了H
hset hmset hget hmget hkeys hvals
HINCRBYFLOAT hash也支持对数值的操作
总结
set
特点:无序的,去重的,不可重复,而list是可以重复的且是有插入顺序的元素排序也是没有的
help @set
SADD SMEMBERS
srem移除
set特殊的一个功能,可以做多个key的交并差集
SINTER 做多个key的交集
SINTERSTORE 会将结果存在一个目标key里
SUNION并集且结果去重
SDIFF差集,是有方向性的
随机事件
SRANDMEMBER
也区分正负数,0不返回
一批人抽3个人中奖,不重复
一批人抽3个奖,可重复(1个人可多次中奖)
一批人(比如7个热)来抽20个奖
还有一个场景,比如公司年会,奖品数一定小于参会人数且还分1等奖2等奖等等
SPOP
set总结
sorted_set
特点:元素是排序的,去重的
理解sorted_set要理解元素是根据排序依据来排序的
help @sorted_set
命令开头基本上都是Z开头的
ZADD添加元素
ZRANGE
ZRANGEBYSCORE
比如想取价格由低到高的前2名,该怎么做呢
ZRANGE k1 0 1
比如想取价格由高到低的前2名呢
ZrevRANGE k1 0 1 反向命令(比如取出网易云播放量前10名的歌曲,这个数据就是倒序,因为sorted-set在物理存放的时候是由小到大存放的)
ZRANGE k1 -2 -1这个取法还是改变不了顺序
ZSCORE查分值
ZRANK查排名
ZINCRBY也支持数值计算
也支持交并差集
ZUNIONSTORE
不带权重、分值,默认是将分值相加
带上权重
带上分值
是怎么实现排序的呢
使用跳跃表,大致结果就是在链表的基础上增加层(基于二分),上面的每一层都像是链表,随即造层是牺牲存储空间来换取查询效率
sorted_set总结