NoSQL-Redis入门(二)-阿里云开发者社区

开发者社区> 数据库> 正文
登录阅读全文

NoSQL-Redis入门(二)

简介: Redis要点: 1.关键字(keys)用于标识一段数据的字符串 2.值(values)是一段任意的字节序列,Redis不会关注他们实质是什么 3.Redis展示了5种专门的数据结构 4.上面几点使得Redis快速而且容易使用,但Redis不适用于所有的应用场景 1.Redis的数据结构 每种数据结构的要点包括: 1.是什么? 2.包含的有效方法 3.使用这些数据结构能处理哪些类型的特性和数据 1.1 字符串(String) 在Redis里,字符串是最基本的数据结构。

Redis要点:

1.关键字(keys)用于标识一段数据的字符串
2.值(values)是一段任意的字节序列,Redis不会关注他们实质是什么
3.Redis展示了5种专门的数据结构
4.上面几点使得Redis快速而且容易使用,但Redis不适用于所有的应用场景

1.Redis的数据结构


每种数据结构的要点包括:

1.是什么?
2.包含的有效方法
3.使用这些数据结构能处理哪些类型的特性和数据

1.1 字符串(String)
在Redis里,字符串是最基本的数据结构。
for example

set users:leto "{name: leto, planet: dune, likes: [spice]}"

Redis是怎么知道我们是在使用哪个数据结构?其解决方法是,每个命令都相对应于一种特定的数据结构。例如,当你使用 set 命令,你就是将值存储到一个字符串数据结构里。而当你使用 hset 命令,你就是将值存储到一个散列数据结构里。考虑到Redis的关键字集很小,这样的机制具有相当的可管理性。
正如上述:
我们已经看到了一个常见的字符串使用案例,即通过关键字存储对象的实例。
我们可以通过下面的命令进行实操:

127.0.0.1:6379> set user:liutao "{name:liutao,age:23,likes[ad,dd]}"
OK
127.0.0.1:6379> get user:liutao
"{name:liutao,age:23,likes[ad,dd]}"
127.0.0.1:6379> strlen user:liutao
(integer) 33
127.0.0.1:6379> getrange user:liutao 27 40
"d,dd]}"
127.0.0.1:6379> append user:liutao ",sex:male"
(integer) 42
127.0.0.1:6379>

get: 根据关键字获取关键字对应的值
strlen:获取关键字对应的值的长度
getrange:获取关键字对应的值从起始索引到末尾索引的值
append: 在关键字对应值末尾添加新的字符串

string类型是Redis最基本的数据类型,一个键最大能存储512MB。

1.2 Hash(哈希)
Redis hash 是一个键值对集合
Redis hash是一个string类型的field和value的映射表,hash特别适合用于存储对象。

img_a95acdcb79d916f0489fa59072337dc4.png

for example

127.0.0.1:6379> hmset user name zhangxiao age 23 sex famale
OK
127.0.0.1:6379> hgetall user
1) "name"
2) "zhangxiao"
3) "age"
4) "23"
5) "sex"
6) "famale"
127.0.0.1:6379>

以上实例中 hash 数据类型存储了包含用户脚本信息的用户对象。 实例中我们使用了 Redis hmset,hgetall 命令,user 为键值。
每个 hash 可以存储 232
-1 键值对(40多亿)。

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

127.0.0.1:6379> lpush zhangxiao 13 175cm
(integer) 4
127.0.0.1:6379> lrange zhangxiao 0 1
1) "175cm"
2) "13"
127.0.0.1:6379>

lpush 向redis集合中存储一系列字符串,使用lrange [start][end] 获取相应的元素值。
列表最多可存储 232

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

1.4 Set(集合)
Redis的Set是string类型的无序集合。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
for example

127.0.0.1:6379> sadd ages 11
(integer) 1
127.0.0.1:6379> add ages 12
(error) ERR unknown command 'add'
127.0.0.1:6379> sadd ages 14
(integer) 1
127.0.0.1:6379> sadd ages 14
(integer) 0
127.0.0.1:6379> sadd ages 15
(integer) 1
127.0.0.1:6379> smembers ages
1) "11"
2) "14"
3) "15"
127.0.0.1:6379>

可以看到我们为ages集合添加了两次14 ,但是最终set集合中只存在一个14,这是因为set集合中的元素唯一性导致的,第二次插入的元素将被忽略。集合中最大的成员数为 2的32次方 - 1(4294967295, 每个集合可存储40多亿个成员)。

** 1.5 zset(sorted set:有序集合)**
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。
for example

127.0.0.1:6379> zadd nums 0 11
(integer) 0
127.0.0.1:6379> zadd nums 1 12
(integer) 1
127.0.0.1:6379> zadd nums 2 13
(integer) 1
127.0.0.1:6379> zrangebyscore nums 0 2
1) "11"
2) "12"
3) "13"

Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。redis正是通过分数来为集合中的成员进行从小到大的排序。
zset的成员是唯一的,但分数(score)却可以重复。
基本的数据结构就是这些,接下来我会更加详细的来进行记录。

博客搬家:大坤的个人博客
欢迎评论哦~

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

其他文章