Redis 数据类型

Redis支持五种数据类型: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 "runoob"
OK
redis 127.0.0.1:6379> GET name
"runoob"
 
 
 
4
 
 
 
 
 
1
redis 127.0.0.1:6379> SET name "runoob"
2
OK
3
redis 127.0.0.1:6379> GET name
4
"runoob"
 
 

在以上实例中我们使用了 Redis 的 SET  GET 命令。键为 name,对应的值为 runoob

注意:一个键最大能存储512MB。


Hash(哈希)

Redis hash 是一个键值(key=>value)对集合。

Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。

实例

127.0.0.1:6379> HMSET user:1 username runoob password runoob points 200
OK
127.0.0.1:6379> HGETALL user:1
1) "username"
2) "runoob"
3) "password"
4) "runoob"
5) "points"
6) "200"
 
 
 
9
 
 
 
 
 
1
127.0.0.1:6379> HMSET user:1 username runoob password runoob points 200
2
OK
3
127.0.0.1:6379> HGETALL user:1
4
1) "username"
5
2) "runoob"
6
3) "password"
7
4) "runoob"
8
5) "points"
9
6) "200"
 
 

以上实例中 hash 数据类型存储了包含用户脚本信息的用户对象。 实例中我们使用了 Redis HMSET, HGETALL 命令,user:1为键值。

每个 hash 可以存储 232 -1 键值对(40多亿)。

 


List(列表)

Redis 列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。

实例

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 rabitmq
(integer) 3
redis 127.0.0.1:6379> lrange runoob 0 10
1) "rabitmq"
2) "mongodb"
3) "redis"
redis 127.0.0.1:6379>
 
 
 
11
 
 
 
 
 
1
redis 127.0.0.1:6379> lpush runoob redis
2
(integer) 1
3
redis 127.0.0.1:6379> lpush runoob mongodb
4
(integer) 2
5
redis 127.0.0.1:6379> lpush runoob rabitmq
6
(integer) 3
7
redis 127.0.0.1:6379> lrange runoob 0 10
8
1) "rabitmq"
9
2) "mongodb"
10
3) "redis"
11
redis 127.0.0.1:6379>
 
 

列表最多可存储 232 - 1 元素 (4294967295, 每个列表可存储40多亿)。


Set(集合)

Redis的Set是string类型的无序集合。

集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。

sadd 命令

添加一个string元素到,key对应的set集合中,成功返回1,如果元素已经在集合中返回0,key对应的set不存在返回错误。

sadd key member
 
 
 
1
 
 
 
 
 
1
sadd key member
 
 

实例

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 rabitmq
(integer) 1
redis 127.0.0.1:6379> sadd runoob rabitmq
(integer) 0
redis 127.0.0.1:6379> smembers runoob

1) "rabitmq"
2) "mongodb"
3) "redis"
 
 
 
13
 
 
 
 
 
1
redis 127.0.0.1:6379> sadd runoob redis
2
(integer) 1
3
redis 127.0.0.1:6379> sadd runoob mongodb
4
(integer) 1
5
redis 127.0.0.1:6379> sadd runoob rabitmq
6
(integer) 1
7
redis 127.0.0.1:6379> sadd runoob rabitmq
8
(integer) 0
9
redis 127.0.0.1:6379> smembers runoob
10

11
1) "rabitmq"
12
2) "mongodb"
13
3) "redis"
 
 

注意:以上实例中 rabitmq 添加了两次,但根据集合内元素的唯一性,第二次插入的元素将被忽略。

集合中最大的成员数为 232 - 1(4294967295, 每个集合可存储40多亿个成员)。


zset(sorted set:有序集合)Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。

 

不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。

zset的成员是唯一的,但分数(score)却可以重复。

zadd 命令

添加元素到集合,元素在集合中存在则更新对应score

zadd key score member 
 
 
 
1
 
 
 
 
 
1
zadd key score member 
 
 

实例

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 rabitmq
(integer) 1
redis 127.0.0.1:6379> zadd runoob 0 rabitmq
(integer) 0
redis 127.0.0.1:6379> ZRANGEBYSCORE runoob 0 1000

1) "redis"
2) "mongodb"
3) "rabitmq"
 
 
 
x
 
 
 
 
 
1
redis 127.0.0.1:6379> zadd runoob 0 redis
2
(integer) 1
3
redis 127.0.0.1:6379> zadd runoob 0 mongodb
4
(integer) 1
5
redis 127.0.0.1:6379> zadd runoob 0 rabitmq
6
(integer) 1
7
redis 127.0.0.1:6379> zadd runoob 0 rabitmq
8
(integer) 0
9
redis 127.0.0.1:6379> ZRANGEBYSCORE runoob 0 1000
10

11
1) "redis"
12
2) "mongodb"
13
3) "rabitmq"
 
 

 

<wiz_tmp_tag id="wiz-table-range-border" contenteditable="false" style="display: none;">





posted @ 2018-03-12 16:32  蓝天浔  阅读(230)  评论(0编辑  收藏  举报