redis key设计技巧

  1. 把表名转换为key前缀,
  2. 第二端放置表用于区分区key的字段–对应mysql中的主键的列名如userid。
    3.放置主键值,如1,2,3,…..,a,b,c。
    4.放要存储的列名
    user表
userid user_name password email
1 zhangsan toor [email protected]

set user:userid:1:user_name zhangsan
set user:userid:1:password toor
set user:userid:1:email [email protected]
keys user:userid:1*
redis key设计技巧_第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)