Doctor_me 2019-07-17 18:13 采纳率: 0%
浏览 737
已采纳

用Redis和Mysql搭建的框架,查数据的时候有没有比较好的方案?

毕业生刚接触redis,现在框架是redis和mysql。在数据库存了一些需要用来做条件查询的字段。

举个例子,redis里面Hash存了编号,姓名,性别,年龄。mysql也存了这些,编号为主键。(也有很多Hash存的键比较多,而mysql里面存的少量筛选条件)

查数据的时候是直接通过筛选条件获取mysql的所有字段的值(select * ),还是根据筛选条件获取符合条件的id列表(select Id )然后根据id从redis取出对应的数据?

这两种方式哪种效率高?对于大数据量(记录特别多,字段特别多)的时候哪种方式更好?

感谢大佬指导!

  • 写回答

2条回答 默认 最新

  • 积跬步以至千里。 2019-07-17 18:41
    关注
    1. redis是内存数据库,数据存放在内存中,根据key检索会很快,但是检索的方式单一,只能通过key进行检索,如果需要通过key进行复杂检索,需要根据实际情况设计key的结构

    2. mysql关系型数据库,支持丰富的查询方式,可以通过添加索引的方式,提高查询速度,如果通过mysql进行查询,没必要先取出id,通过redis取详细内容,因为整个过程比较慢的是按条件筛选,而不是最后取出来的字段内容,总之,关系型数据库,查询条件越复杂,速度越慢

    3. 这些只是简单的回答,你的问题涉及的东西蛮多,具体方案确定一定要根据你的实际使用场景决定。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 韩国网站购物,KG支付的支付回调如何解决
  • ¥15 workstation导入ovf文件,报错,怎么解决呢?
  • ¥15 关于#c语言#的问题:构成555单稳态触发器,采用LED指示灯延时时间,对延时时间进行测量并显示(如楼道声控延时灯)需要Proteus仿真图和C语言代码
  • ¥15 workstation加载centos进入emergency模式,查看日志报警如图,怎样解决呢?
  • ¥50 如何用单纯形法寻优不能精准找不到给定的参数,并联机构误差识别,给定误差有7个?matlab
  • ¥15 workstation加载centos进入emergency模式,查看日志报警如图,没有XFS,怎样解决呢?
  • ¥15 应用商店如何检测在架应用内容是否违规?
  • ¥15 Ubuntu系统配置PX4
  • ¥50 nw.js调用activex
  • ¥15 数据库获取信息反馈出错,直接查询了ref字段并且还使用了User文档的_id而不是自己的