数据类型
# 数据类型
Redis支持五种数据类型:
string(字符串)
,hash(哈希)
,list(列表)
,set(集合
)及zset(sorted set:有序集合)
。
# String(字符串)
string
是 redis
最基本的类型,你可以理解成与 Memcached
一模一样的类型,一个 key
对应一个 value
。
string
类型是二进制安全的。意思是 redis
的 string
可以包含任何数据。比如jpg图片或者序列化的对象。
string
类型是 Redis
最基本的数据类型,string
类型的值最大能存储 512MB。
redis 127.0.0.1:6379> SET dong "东哥天下"
OK
redis 127.0.0.1:6379> GET dong
"东哥天下"
2
3
4
# Hash(哈希)
Redis hash
是一个键值(key=>value
)对集合。
Redis hash
是一个 string
类型的 field
和 value
的映射表,hash
特别适合用于存储对象。
redis 127.0.0.1:6379> DEL runoob
redis 127.0.0.1:6379> HMSET runoob field1 "Hello" field2 "World"
"OK"
redis 127.0.0.1:6379> HGET runoob field1
"Hello"
redis 127.0.0.1:6379> HGET runoob field2
"World"
2
3
4
5
6
7
注意: 每个 hash
可以存储 232 -1
键值对(40
多亿)。
# List(列表)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。
redis 127.0.0.1:6379> DEL runoob
redis 127.0.0.1:6379> lpush runoob redis
(integer) 1
redis 127.0.0.1:6379> lpush runoob mongodb
(integer) 2
redis 127.0.0.1:6379> lpush runoob rabbitmq
(integer) 3
# 遍历输出列表
redis 127.0.0.1:6379> lrange runoob 0 10
1) "rabbitmq"
2) "mongodb"
3) "redis"
redis 127.0.0.1:6379>
2
3
4
5
6
7
8
9
10
11
12
13
14
注意: 列表最多可存储 232 - 1
元素 (4294967295
, 每个列表可存储40多亿)。
# Set(集合)
Redis
的Set
是string
类型的无序集合。集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是 O(1)。
# sadd 命令
添加一个 string
元素到 key
对应的 set
集合中,成功返回 1
,如果元素已经在集合中返回 0
。
sadd key member
redis 127.0.0.1:6379> DEL runoob
redis 127.0.0.1:6379> sadd runoob redis
(integer) 1
redis 127.0.0.1:6379> sadd runoob mongodb
(integer) 1
redis 127.0.0.1:6379> sadd runoob rabbitmq
(integer) 1
redis 127.0.0.1:6379> sadd runoob rabbitmq
(integer) 0
redis 127.0.0.1:6379> smembers runoob
1) "redis"
2) "rabbitmq"
3) "mongodb"
2
3
4
5
6
7
8
9
10
11
12
13
14
- smembers 遍历集合
注意: 以上实例中 rabbitmq
添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。集合中最大的成员数为 232 - 1
(4294967295, 每个集合可存储40多亿个成员)。
# zset(sorted set:有序集合)
Redis
zset
和set
一样也是string
类型元素的集合,且不允许重复的成员。不同的是每个元素都会关联一个double
类型的分数。redis
正是通过分数来为集合中的成员进行从小到大的排序。
zset
的成员是唯一的,但分数(score
)却可以重复。
# zadd 命令
添加元素到集合,元素在集合中存在则更新对应score
zadd key score member
redis 127.0.0.1:6379> DEL runoob
redis 127.0.0.1:6379> zadd runoob 0 redis
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 mongodb
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 rabbitmq
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 rabbitmq
(integer) 0
redis 127.0.0.1:6379> ZRANGEBYSCORE runoob 0 1000
1) "mongodb"
2) "rabbitmq"
3) "redis"
2
3
4
5
6
7
8
9
10
11
12
13
# 应用场景
类型 | 简介 | 特性 | 场景 |
---|---|---|---|
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、带权重的消息队列 |