美文网首页Redis专题
NoSQL-Redis入门(二)

NoSQL-Redis入门(二)

作者: markfork | 来源:发表于2016-11-28 13:43 被阅读58次

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特别适合用于存储对象。


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)却可以重复。
基本的数据结构就是这些,接下来我会更加详细的来进行记录。

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

相关文章

  • NoSQL-Redis入门(二)

    Redis要点: 1.关键字(keys)用于标识一段数据的字符串2.值(values)是一段任意的字节序列,Red...

  • NoSql-Redis入门(事务)

    定义 Redis 事务可以一次执行多个命令, 并且带有以下两个重要的保证:1.事务是一个单独的隔离操作:事务中的所...

  • NoSQL-Redis入门(一)

    从这篇开始记录Redis相关知识: 1 NoSQL是什么?1.1 NoSQL特性1.1.1 易扩展1.1.2 大数...

  • 【redis】redis运维监控

    Redis进阶 - 运维监控https://www.pdai.tech/md/db/nosql-redis/db-...

  • NoSQL-redis

    安装 下载:打开redis官方网站,推荐下载稳定版本(stable) 解压 免费开源redis可视化客户端工具:(...

  • NoSQL-redis

    0. NoSQL 产品(key-value) 1. Redis功能介绍 2、企业缓存产品介绍 3、Redis使用场...

  • springboot+Spring Cloud-hystrix整

    Dubbo入门案例(一)Dubbo入门案例(二)Dubbo入门案例(三)Dubbo入门案例(四)Dubbo入门案例...

  • dubbo服务降级(五)

    Dubbo入门案例(一)Dubbo入门案例(二)Dubbo入门案例(三)Dubbo入门案例(四)Dubbo入门案例...

  • dubbo集群实现负载均衡配置(四)

    Dubbo入门案例(一)Dubbo入门案例(二)Dubbo入门案例(三)Dubbo入门案例(四)Dubbo入门案例...

  • Dubbo使用@Transactional,服务发布不成功(二)

    Dubbo入门案例(一)Dubbo入门案例(二)Dubbo入门案例(三)Dubbo入门案例(四)Dubbo入门案例...

网友评论

    本文标题:NoSQL-Redis入门(二)

    本文链接:https://www.haomeiwen.com/subject/vwhopttx.html