Redis五种数据类型
- 1.String
- 1.1特点
- 1.2命令
- 1.3实例
- 2.Hash
- 2.1特点
- 2.2命令
- 2.3实例
- 3.List
- 3.1特点
- 3.2命令
- 3.3实例
- 4.Set
- 4.1特点
- 4.2命令
- 4.3实例
- 5. SortedSet
- 5.1特点
- 5.2命令
- 5.3实例
1.String
1.1特点
String类型,也就是字符串类型,是Redis中最简单的存储类型。
其value是字符串
,不过根据字符串的格式不同,又可以分为3类:
- string:普通字符串
- int:整数类型,可以做自增、自减操作
- float:浮点类型,可以做自增、自减操作
不管是哪种格式,底层都是字节数组形式存储,只不过是编码方式不同。字符串类型的最大空间不能超过512m.
1.2命令
String的常见命令有:
- SET:添加或者修改已经存在的一个String类型的键值对
- GET:根据key获取String类型的value
- MSET:批量添加多个String类型的键值对
- MGET:根据多个key获取多个String类型的value
- INCR:让一个整型的key自增1
- INCRBY:让一个整型的key自增并指定步长,例如:incrby num 2 让num值自增2
- INCRBYFLOAT:让一个浮点类型的数字自增并指定步长
- SETNX:添加一个String类型的键值对,前提是这个key不存在,否则不执行
- SETEX:添加一个String类型的键值对,并且指定有效期
1.3实例
127.0.0.1:6379[6]> set str helloword
OK
127.0.0.1:6379[6]> get str
"helloword"
127.0.0.1:6379[6]> mset strs ljl age 10 score 89.1
OK
127.0.0.1:6379[6]> mget strs age score
1) "ljl"
2) "10"
3) "89.1"
127.0.0.1:6379[6]> incr age
(integer) 11
127.0.0.1:6379[6]> incrby age 3
(integer) 14
127.0.0.1:6379[6]> incrbyfloat score 10
"99.1"
127.0.0.1:6379[6]> get age
"14"
127.0.0.1:6379[6]> setnx age 15
(integer) 0
127.0.0.1:6379[6]> get age
"14"
127.0.0.1:6379[6]> setnx age0 14
(integer) 1
127.0.0.1:6379[6]> get age0
"14"
127.0.0.1:6379[6]> setex age0 10 15
OK
127.0.0.1:6379[6]> get age0
"15"
127.0.0.1:6379[6]> get age0
"15"
127.0.0.1:6379[6]> ttl ageo
(integer) -2
127.0.0.1:6379[6]> ttl age0
(integer) -2
127.0.0.1:6379[6]> setex age0 100 15
OK
127.0.0.1:6379[6]> ttl age0
(integer) 94
127.0.0.1:6379[6]> ttl age0
(integer) 92
127.0.0.1:6379[6]> ttl age0
(integer) 91
127.0.0.1:6379[6]>
2.Hash
2.1特点
Hash类型,也叫散列,其value是一个无序字典
,类似于Java中的HashMap结构。
String结构是将对象序列化为JSON字符串后存储,当需要修改对象某个字段时很不方便
Hash结构可以将对象中的每个字段独立存储,可以针对单个字段做CRUD
2.2命令
Hash的常见命令有:
-
HSET key field value:添加或者修改hash类型key的field的值
-
HGET key field:获取一个hash类型key的field的值
-
HMSET:批量添加多个hash类型key的field的值
-
HMGET:批量获取多个hash类型key的field的值
-
HGETALL:获取一个hash类型的key中的所有的field和value
-
HKEYS:获取一个hash类型的key中的所有的field
-
HINCRBY:让一个hash类型key的字段值自增并指定步长
-
HSETNX:添加一个hash类型的key的field值,前提是这个field不存在,否则不执行
2.3实例
127.0.0.1:6379[7]> hset h name ljl age 120 score 99.8
(integer) 3
127.0.0.1:6379[7]> hget h name
"ljl"
127.0.0.1:6379[7]> hmset h1 name lisi age 10
OK
127.0.0.1:6379[7]> hmget h name age score
1) "ljl"
2) "120"
3) "99.8"
127.0.0.1:6379[7]> hgetall h
1) "name"
2) "ljl"
3) "age"
4) "120"
5) "score"
6) "99.8"
127.0.0.1:6379[7]> hkeys h
1) "name"
2) "age"
3) "score"
127.0.0.1:6379[7]> hincrby h score 10
(error) ERR hash value is not an integer
127.0.0.1:6379[7]> hincrbyfloat h score 10
"109.8"
127.0.0.1:6379[7]> hsetnx h sex 1
(integer) 1
127.0.0.1:6379[7]>
3.List
3.1特点
Redis中的List类型与Java中的LinkedList类似,可以看做是一个双向链表
结构。既可以支持正向检索和也可以支持反向检索。
特征也与LinkedList类似:
- 有序
- 元素可以重复
- 插入和删除快
- 查询速度一般
常用来存储一个有序数据,例如:朋友圈点赞列表,评论列表等。
3.2命令
List的常见命令有:
- LPUSH key element … :向列表左侧插入一个或多个元素
- LPOP key:移除并返回列表左侧的第一个元素,没有则返回nil
- RPUSH key element … :向列表右侧插入一个或多个元素
- RPOP key:移除并返回列表右侧的第一个元素
- LRANGE key star end:返回一段角标范围内的所有元素
- BLPOP和BRPOP:与LPOP和RPOP类似,只不过在没有元素时等待指定时间,而不是直接返回nil
3.3实例
127.0.0.1:6379[8]> lpush list 1 2 3
(integer) 3
127.0.0.1:6379[8]> rpush list 4 5 6
(integer) 6
127.0.0.1:6379[8]> lpop list 1
1) "3"
127.0.0.1:6379[8]> rpop list 2
1) "6"
2) "5"
127.0.0.1:6379[8]> lrange list 0 2
1) "2"
2) "1"
3) "4"
127.0.0.1:6379[8]> blpop list a 100
1) "list"
2) "2"
127.0.0.1:6379[8]> lrange list 0 2
1) "1"
2) "4"
127.0.0.1:6379[8]> blpop list1 1000
1) "list1"
2) "5"
(37.92s)
127.0.0.1:6379[8]> blpop list list1 100
1) "list"
2) "1"
127.0.0.1:6379[8]>
4.Set
4.1特点
Redis的Set结构与Java中的HashSet类似,可以看做是一个value为null的HashMap
。因为也是一个hash表,因此具备与HashSet类似的特征:
-
无序
-
元素不可重复
-
查找快
-
支持交集、并集、差集等功能
4.2命令
Set的常见命令有:
- SADD key member … :向set中添加一个或多个元素
- SREM key member … : 移除set中的指定元素
- SCARD key: 返回set中元素的个数
- SISMEMBER key member:判断一个元素是否存在于set中
- SMEMBERS:获取set中的所有元素
- SINTER key1 key2 … :求key1与key2的交集
- Sdiff key1 key2 … :求key1与key2的差集
- Sunion key1 key2 … :求key1与key2的并集
4.3实例
127.0.0.1:6379[9]> sadd zs ls ww zl
(integer) 3
127.0.0.1:6379[9]> sadd ls ww mz eg
(integer) 3
127.0.0.1:6379[9]> srem zs ls
(integer) 1
127.0.0.1:6379[9]> scard zs
(integer) 2
127.0.0.1:6379[9]> sismember zs ls
(integer) 0
127.0.0.1:6379[9]> sismember zs ww
(integer) 1
127.0.0.1:6379[9]> sinter zs ls
1) "ww"
127.0.0.1:6379[9]> sdiff zs ls
1) "zl"
127.0.0.1:6379[9]> sunion zs ls
1) "ww"
2) "mz"
3) "zl"
4) "eg"
127.0.0.1:6379[9]>
5. SortedSet
5.1特点
Redis的SortedSet是一个可排序的set集合,与Java中的TreeSet有些类似,但底层数据结构却差别很大。SortedSet中的每一个元素都带有一个score属性,可以基于score属性对元素排序
,底层的实现是一个跳表(SkipList)加 hash表。
SortedSet具备下列特性:
- 可排序
- 元素不重复
- 查询速度快
因为SortedSet的可排序特性,经常被用来实现排行榜这样的功能。
5.2命令
SortedSet的常见命令有:
- ZADD key score member:添加一个或多个元素到sorted set ,如果已经存在则更新其score值
- ZREM key member:删除sorted set中的一个指定元素
- ZSCORE key member : 获取sorted set中的指定元素的score值
- ZRANK key member:获取sorted set 中的指定元素的排名
- ZCARD key:获取sorted set中的元素个数
- ZCOUNT key min max:统计score值在给定范围内的所有元素的个数
- ZINCRBY key increment member:让sorted set中的指定元素自增,步长为指定的increment值
- ZRANGE key min max:按照score排序后,获取指定排名范围内的元素
- ZRANGEBYSCORE key min max:按照score排序后,获取指定score范围内的元素
- ZDIFF、ZINTER、ZUNION:求差集、交集、并集
注意:所有的排名默认都是升序,如果要降序则在命令的Z后面添加REV即可,例如:
-
升序获取sorted set 中的指定元素的排名:ZRANK key member
-
降序获取sorted set 中的指定元素的排名:ZREVRANK key memeber
5.3实例
127.0.0.1:6379[10]> zadd sortedSet 85 jack 89 rose 90 tom 75 jerry
(integer) 4
127.0.0.1:6379[10]> zrem sortedSet rose
(integer) 1
127.0.0.1:6379[10]> zscore sortedSet jerry
"75"
127.0.0.1:6379[10]> zrank sortedSet tom
(integer) 2
127.0.0.1:6379[10]> zcard sortedSet
(integer) 3
127.0.0.1:6379[10]> zcount sortedSet 80 90
(integer) 2
127.0.0.1:6379[10]> zincrby sortedSet 10 jack
"95"
127.0.0.1:6379[10]> zrange sortedSet 80 100
(empty array)
127.0.0.1:6379[10]> zrange sortedSet 0 1
1) "jerry"
2) "tom"
127.0.0.1:6379[10]> zrange sortedSet 0 3
1) "jerry"
2) "tom"
3) "jack"
127.0.0.1:6379[10]> zrangeByscore sortedSet 80 100
1) "tom"
2) "jack"
127.0.0.1:6379[10]> zrevrange sortedSet 0 3
1) "jack"
2) "tom"
3) "jerry"
127.0.0.1:6379[10]> zrevrangebyscore sortedSet 80 100
(empty array)
127.0.0.1:6379[10]> zrevrangebyscore sortedSet 100 80
1) "jack"
2) "tom"
127.0.0.1:6379[10]>