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条)

报告相同问题?

悬赏问题

  • ¥20 ML307A在使用AT命令连接EMQX平台的MQTT时被拒绝
  • ¥20 腾讯企业邮箱邮件可以恢复么
  • ¥15 有人知道怎么将自己的迁移策略布到edgecloudsim上使用吗?
  • ¥15 错误 LNK2001 无法解析的外部符号
  • ¥50 安装pyaudiokits失败
  • ¥15 计组这些题应该咋做呀
  • ¥60 更换迈创SOL6M4AE卡的时候,驱动要重新装才能使用,怎么解决?
  • ¥15 让node服务器有自动加载文件的功能
  • ¥15 jmeter脚本回放有的是对的有的是错的
  • ¥15 r语言蛋白组学相关问题