一.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类型
可正向检索和反向检索,和 LinkedList 类似
应用场景:常用来存储一个有序数据,例如:朋友圈点赞列表,评论列表等
示例:
用List结构模拟一个栈:
入口和出口在同一边,即使用LPUSH和LPOP(或RPUSH和RPOP)
用List结构模拟一个队列:
入口和出口在不在同一边
用List结构模拟一个阻塞队列:
入口和出口在不在同一边,并且出队时采用BLPOP或BRPOP
6.Set类型
应用:可以用来实现好友列表、共同好友、关注列表等功能
示例:
7.Zset(SortedSet,跳表+hash表)
底层:跳表+hash表
应用:排行榜等
SortedSet返回的排名是从0开始的
示例:
三.Key的层级形式
1.问题引入
Redis没有类似MySQL中的Table的概念,我们该如何区分不同类型的key呢? 例如,需要存储用户、商品信息到redis,有一个用户id是1,有一个商品id恰好也是1
2.Key的层级形式
四.Redis的Java客户端的对比
SpringDataRedis
RedisTemplate的两种序列化方案
为了在反序列化时知道对象的类型,JSON序列化器会将类的lass类型写入json结果中,存入Redis,会带来额外的内存开销。