Redis是一个开源的使用ANSI C语言编写、遵守BSD协议、支持网络、可基于内存亦可持久化的日志型、Key-Value数据库,并提供多种语言的API,它通常被称为数据结构服务器,支持五种数据类型:string(字符串),hash(哈希),list(列表),set(集合)和zset(sorted set:有序集合)。
string
string是redis最基本的类型,可以理解为与Memcached一模一样的类型,一个key对应一个value。string类型是二进制安全的,即redis的string可以包含任何数据。比如jpg图片或者序列化的对象,string类型是Redis最基本的数据类型,一个键最大能存储512MB。
redis 127.0.0.1:6379> SET name "wunian"
OK
redis 127.0.0.1:6379> GET name
"wunian"
hash
Redis hash 是一个键值(key=>value)对集合,也是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象,每个hash 可以存储 2 ^32-1 键值对(40多亿)。
redis> HMSET hash field1 "Hello" field2 "Redis"
"OK"
redis> HGET hash field1
"Hello"
redis> HGET hash field2
"Redis"
list
Redis list列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边),列表最多可存储2^32 - 1 元素 (4294967295, 每个列表可存储40多亿)。
redis 127.0.0.1:6379> lpush db redis
(integer) 1
redis 127.0.0.1:6379> lpush db mongodb
(integer) 2
redis 127.0.0.1:6379> lpush db rabitmq
(integer) 3
redis 127.0.0.1:6379> lrange db 0 10
1) "rabitmq"
2) "mongodb"
3) "redis"
set
Redis set是string类型的无序集合,集合是通过哈希表实现的,添加,删除,查找的复杂度都是O(1),添加一个string 元素到 key 对应的 set 集合中,成功返回1,如果元素已经在集合中返回 0,如果 key 对应的 set 不存在则返回错误,集合中最大的成员数为2^32 - 1(4294967295, 每个集合可存储40多亿个成员)。
redis 127.0.0.1:6379> sadd db redis
(integer) 1
redis 127.0.0.1:6379> sadd db mongodb
(integer) 1
redis 127.0.0.1:6379> sadd db rabitmq
(integer) 1
redis 127.0.0.1:6379> sadd db rabitmq
(integer) 0
redis 127.0.0.1:6379> smembers db
1) "redis"
2) "rabitmq"
3) "mongodb"
zset
Redis zset和set 一样也是string类型元素的集合,且不允许重复的成员,不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序,zset的成员是唯一的,但分数(score)却可以重复。
redis 127.0.0.1:6379> zadd db 0 redis
(integer) 1
redis 127.0.0.1:6379> zadd db 0 mongodb
(integer) 1
redis 127.0.0.1:6379> zadd db 0 rabitmq
(integer) 1
redis 127.0.0.1:6379> zadd db 0 rabitmq
(integer) 0
redis 127.0.0.1:6379> > ZRANGEBYSCORE db 0 1000
1) "mongodb"
2) "rabitmq"
3) "redis"