11.3 数据类型
Redis数据类型包括:string(字符串),hash(哈希),list(列表),set(集合)及zset(sorted set:有序集合),以下逐一介绍
11.3.0 常见命令
- KEYS:查看符合模板的所有key
- DEL:删除一个指定的key
- EXISTS:判断key是否存在
- EXPIRE:给一个key设置有效期,有效期到期时该key会被自动删除
- TTL:查看一个KEY的剩余有效期
通过help [command] 可以查看一个命令的具体用法,
# 查看keys命令的帮助信息:
127.0.0.1:6379> help keys
KEYS pattern
summary: Find all keys matching the given pattern
since: 1.0.0
group: generic
11.3.1 string(字符串)
string 是 redis 最基本的类型,你可以理解成与 Memcached 一模一样的类型,一个 key 对应一个 value。也就和java中变量都差不多,一个变量对应一个值(形式一样,实质不一样)。
string 类型是二进制安全的。意思是 redis 的 string 可以包含任何数据。比如jpg图片或者序列化的对象。string 类型的值最大能存储 512MB。value工具字符串的格式又分为string,int,float三种。
存取值
> set mykey somevalue
OK
> get mykey
"somevalue"
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类型的键值对,并且指定有效期
11.3.2 hash(哈希)
Redis中的hash(哈希,也叫散列)是一个键值(key=>value)对集合。
hash 是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。就类似于java中的HashMap
redis 127.0.0.1:6379> DEL mykey
redis 127.0.0.1:6379> HMSET mykey field1 "Hello" field2 "World"
"OK"
redis 127.0.0.1:6379> HGET mykey field1
"Hello"
redis 127.0.0.1:6379> HGET mykey field2
"World"
每个 hash 可以存储 232 -1 键值对(40多亿)。
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不存在,否则不执行
11.3.3 List(列表)
List列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
双向链表,可以类比Java中的LinkedList
redis 127.0.0.1:6379> DEL mykey
redis 127.0.0.1:6379> lpush mykey redis
(integer) 1
redis 127.0.0.1:6379> lpush mykey mongodb
(integer) 2
redis 127.0.0.1:6379> lpush mykey rabbitmq
(integer) 3
redis 127.0.0.1:6379> lrange mykey 0 10
1) "rabbitmq"
2) "mongodb"
3) "redis"
redis 127.0.0.1:6379>
列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。
List的常见命令有:
- LPUSH key element … :向列表左侧插入一个或多个元素
- LPOP key:移除并返回列表左侧的第一个元素,没有则返回nil
- RPUSH key element … :向列表右侧插入一个或多个元素
- RPOP key:移除并返回列表右侧的第一个元素
- LRANGE key star end:返回一段角标范围内的所有元素
- BLPOP和BRPOP:与LPOP和RPOP类似,只不过在没有元素时等待指定时间,而不是直接返回nil
11.3.4 Set(集合)
Redis 的 Set 是 string 类型的无序集合。类比Java中的HashSet
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。
sadd 命令:添加一个 string 元素到 key 对应的 set 集合中,成功返回 1,如果元素已经在集合中返回 0。
sadd key member
实例
redis 127.0.0.1:6379> DEL mykey
redis 127.0.0.1:6379> sadd mykey redis
(integer) 1
redis 127.0.0.1:6379> sadd mykey mongodb
(integer) 1
redis 127.0.0.1:6379> sadd mykey rabbitmq
(integer) 1
redis 127.0.0.1:6379> sadd mykey rabbitmq
(integer) 0
redis 127.0.0.1:6379> smembers mykey
1) "redis"
2) "rabbitmq"
3) "mongodb"
**注意:**以上实例中 rabbitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。
集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。
Set的常见命令有:
- SADD key member … :向set中添加一个或多个元素
- SREM key member … : 移除set中的指定元素
- SCARD key: 返回set中元素的个数
- SISMEMBER key member:判断一个元素是否存在于set中
- SMEMBERS:获取set中的所有元素
- SINTER key1 key2 … :求key1与key2的交集
11.3.5 zset(sorted set:有序集合)
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。类比Java中的TreeSet
不同的是zset每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。
zadd 命令:添加元素到集合,元素在集合中存在则更新对应score
zadd key score member
实例
redis 127.0.0.1:6379> DEL mykey
redis 127.0.0.1:6379> zadd mykey 0 redis
(integer) 1
redis 127.0.0.1:6379> zadd mykey 0 mongodb
(integer) 1
redis 127.0.0.1:6379> zadd mykey 0 rabbitmq
(integer) 1
redis 127.0.0.1:6379> zadd mykey 0 rabbitmq
(integer) 0
redis 127.0.0.1:6379> ZRANGEBYSCORE mykey 0 1000
1) "mongodb"
2) "rabbitmq"
3) "redis"
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
11.3.6 应用场景
类型 | 简介 | 特性 | 场景 |
---|---|---|---|
String(字符串) | 二进制安全 | 可以包含任何数据,比如jpg图片或者序列化的对象,一个键最大能存储512M | — |
Hash(字典) | 键值对集合,即编程语言中的Map类型 | 适合存储对象,并且可以像数据库中update一个属性一样只修改某一项属性值(Memcached中需要取出整个字符串反序列化成对象修改完再序列化存回去) | 存储、读取、修改用户属性 |
List(列表) | 链表(双向链表) | 增删快,提供了操作某一段元素的API | 1,最新消息排行等功能(比如朋友圈的时间线) 2,消息队列 |
Set(集合) | 哈希表实现,元素不重复 | 1、添加、删除,查找的复杂度都是O(1) 2、为集合提供了求交集、并集、差集等操作 | 1、共同好友 2、利用唯一性,统计访问网站的所有独立ip 3、好友推荐时,根据tag求交集,大于某个阈值就可以推荐 |
Sorted Set(有序集合) | 将Set中的元素增加一个权重参数score,元素按score有序排列 | 数据插入集合时,已经进行天然排序 | 1、排行榜 2、带权重的消息队列 |