Thinkphp中mysql两表查询用in ids还是left join(分页的情况,ids数组一般20个左右)?

不清楚哪种解决方案好
在书上看到说是 一般都是分表查询,有利于缓存

阅读 4.3k
3 个回答

这两个的语法使用的场景是不一样的,in是知道了id去筛选出符合你id组的记录,而left join是关联表。如果是我做分页的话,看关联的表是不是大表(几十万上百万记录),再决定是否使用left join ,即使是使用join最好explain一下看看是不是达到最优了,没有的话,看看explain结果进行优化一下。建议超大表不要join;用in的话,提取id和查询副表组装数据进入主表数据集的时候不要多重循环,效率也不见得慢到哪去。

最简单的办法就是用关联模型

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题