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 网络科学导论,网络控制
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)