key设计 短信验证存redis_redis key设计技巧

把表名转换为key前缀, 第二端放置表用于区分区key的字段–对应mysql中的主键的列名如userid。

3.放置主键值,如1,2,3,…..,a,b,c。

4.放要存储的列名

user表 userid user_name password email 1 zhangsan toor 666@abc.com

set user:userid:1:user_name zhangsan

set user:userid:1:password toor

set user:userid:1:email 666@abc.com

keys user:userid:1*

在分布式存储时, 只对user:userid:1进行hash,只要是同一个人的信息都将hash到同一台服务器。 注意

在关系型数据中,除了主键外,还有可能其他列来进行查询。

如上表,user_name也是极其频繁查询的,往往这样的列也是加了索引的。

转换到k-v数据中,则也要相应的生成一条按照该列为主的key-value

set user_name:zhangsan:userid 1

这样,我们就可以根据user_name:zhangsan:userid,查询出userid为1

再根据user:userid:1:列名

查询出用户的信息。

如果经常要根据email来查询,那么同样的需要维护email->id的映射,虽然这样造成了冗余,但是提升了速度,减少了时间,用空间换时间。

空间和时间不可兼得。

以上是云栖社区小编为您精心准备的的内容,在云栖社区的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索设计 , redis 表映射 ,以便于您获取更多的相关知识。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值