一.NoSQL
1.认识NoSQL
关系型数据库:结构化(有很多约束),关联的(数据库会自己维护数据之间的关联,如外键),SQL查询(语法统一),满足事务ACID的特性
非关系型数据库:非结构化,无关联的,非SQL,BASE(只是基本满足事务或者无法满足)
常见类型:①键值对key-value(如redis)
②文档型document(如MongoDB)
③图类型(如Neo4j)
④列类型(如HBase)
2.redis的特点
二.Redis数据结构
1.数据结构介绍
2.redis通用命令
3.String类型
redis会将数字转成二进制的形式作为字节存储,更加节省空间,而字符串只能把字符转成对应的字节码再去存储,占用的空间更多一点
示例:
4.Hash类型
示例:
5.List类型
示例:
用List结构模拟一个栈:
入口和出口在同一边,即使用LPUSH和LPOP(或RPUSH和RPOP)
用List结构模拟一个队列:
入口和出口在不在同一边
用List结构模拟一个阻塞队列:
入口和出口在不在同一边,并且出队时采用BLPOP或BRPOP
6.Set类型
应用:可以用来实现好友列表、共同好友、关注列表等功能
示例:
7.SortedSet
SortedSet返回的排名是从0开始的
示例:
三.Key的层级形式
1.问题引入
Redis没有类似MySQL中的Table的概念,我们该如何区分不同类型的key呢? 例如,需要存储用户、商品信息到redis,有一个用户id是1,有一个商品id恰好也是1