1.string
redis最基本的类型,你可以理解成与Memcached一模一样的类型,一个key对应一个value。
string类型是二进制安全的。意思是redis的string可以包含任何数据。比如jpg图片或者序列化的对象 。
string类型是Redis最基本的数据类型,一个键最大能存储512MB。
1 2 3 4 5 6 7
| 1. redis 127.0.0.1:6379> SET name "redis.net.cn"
2. OK
3. redis 127.0.0.1:6379> GET name
4. "redis.net.cn"
|
2.Hash(哈希)
Redis hash 是一个键值对集合。
Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。
每个 hash 可以存储 232 - 1 键值对(40多亿)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
| 1. redis 127.0.0.1:6379> HMSET user:1 username redis.net.cn password redis.net.cn points 200
2. OK
3. redis 127.0.0.1:6379> HGETALL user:1
4. 1) "username"
5. 2) "redis.net.cn"
6. 3) "password"
7. 4) "redis.net.cn"
8. 5) "points"
9. 6) "200"
10. redis 127.0.0.1:6379>
|
实例中我们使用了 Redis HMSET, HEGTALL 命令,user:1 为键值。
3.List(列表)
Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素导列表的头部(左边)或者尾部(右边)。
列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21
| 1. redis 127.0.0.1:6379> lpush redis.net.cn redis
2. (integer) 1
3. redis 127.0.0.1:6379> lpush redis.net.cn mongodb
4. (integer) 2
5. redis 127.0.0.1:6379> lpush redis.net.cn rabitmq
6. (integer) 3
7. redis 127.0.0.1:6379> lrange redis.net.cn 0 10
8. 1) "rabitmq"
9. 2) "mongodb"
10. 3) "redis"
11. redis 127.0.0.1:6379>
|
4.Set(集合)
Redis的Set是string类型的无序集合。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
sadd 命令
添加一个string元素到,key对应的set集合中,成功返回1,如果元素以及在集合中返回0,key对应的set不存在返回错误
集合中最大的成员数为 232 - 1 (4294967295, 每个集合可存储40多亿个成员)。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
| 1. sadd key member
1. redis 127.0.0.1:6379> sadd redis.net.cn redis
2. (integer) 1
3. redis 127.0.0.1:6379> sadd redis.net.cn mongodb
4. (integer) 1
5. redis 127.0.0.1:6379> sadd redis.net.cn rabitmq
6. (integer) 1
7. redis 127.0.0.1:6379> sadd redis.net.cn rabitmq
8. (integer) 0
9. redis 127.0.0.1:6379> smembers redis.net.cn
10.
11. 1) "rabitmq"
12. 2) "mongodb"
13. 3) "redis"
|
注意:以上实例中 rabitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。
6.zset(sorted set:有序集合)
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。
zadd 命令
添加元素到集合,元素在集合中存在则更新对应score
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
| 1. zadd key score member
1. redis 127.0.0.1:6379> zadd redis.net.cn 0 redis
2. (integer) 1
3. redis 127.0.0.1:6379> zadd redis.net.cn 0 mongodb
4. (integer) 1
5. redis 127.0.0.1:6379> zadd redis.net.cn 0 rabitmq
6. (integer) 1
7. redis 127.0.0.1:6379> zadd redis.net.cn 0 rabitmq
8. (integer) 0
9. redis 127.0.0.1:6379> ZRANGEBYSCORE redis.net.cn 0 1000
10.
11. 1) "redis"
12. 2) "mongodb"
13. 3) "rabitmq"
|