redis数据库数据的存储方式

在平时的开发中,我们会有这种场景,对性能要求很高,但数据量很大,如果纯粹使用数据库,可能性能会有问题,这时,我们就可以使用redis来分担部分性能压力,将数据存储到redis中,页面展示等依旧是数据库,但需要高效查询的部分则使用redis.。

redis数据库设计可以有以下几种方式

1.使用唯一性的字段作为key,其余部分使用json将此行数据库数据存入redis的value中。 如  key -> 表名_主键值  value->行对象的json字符串,此种方式适合需要一次查询出整行的数据。缺点,序列化和反序列化会消耗时间,如果修改,在并发下可能会有问题,因为是对整个对象进行的,可能覆盖前一次操作。

2.key->表名_主键值_列名    value->列的值,这种方式是每一列数据都采用key-value这种方式,这种方式避免了上面的问题,由于key的重复存储,消耗的内存非常可观。

3.使用hash存储,key依旧是需要查询的唯一性字段,value是一个Map,这个Map的key是成员的属性名,value是属性值,这样对数据的修改和存取都可以直接通过其内部Map的Key。一个hash里面的数量最好不要大于1000,否则可能导致效率急剧下降。

上面已经说到Redis Hash对应Value内部实际就是一个HashMap,实际这里会有2种不同实现,这个Hash的成员比较少时Redis为了节省内存会采用类似一维数组的方式来紧凑存储,而不会采用真正的HashMap结构,对应的value redisObject的encoding为zipmap,当成员数量增大时会自动转成真正的HashMap,此时encoding为ht。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值