zoukankan      html  css  js  c++  java
  • 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 表映射 ,以便于您获取更多的相关知识。

  • 相关阅读:
    MFC程序自动生成dump Windbg文件
    .net 播放音频(使用winmm.dll)
    media player 网页代码属性
    标记ATL控件为安全控件
    js方法重写
    cab包inf文件配置
    凌阳单片机(61板)USB下载线原理与制作
    html 智能检查,修复
    差异性发展 浙江工商局长郑宇民“智斗”央视女主持董倩
    什么是有效高效的沟通
  • 原文地址:https://www.cnblogs.com/wntd/p/9617297.html
Copyright © 2011-2022 走看看