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

WBOY
Lepaskan: 2023-03-03 10:16:01
asal
1428 orang telah melayarinya

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

回复内容:

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

主要看数据量,以及应用场景,数据量小情况下,俩差不多
where in()查询还是多表 left join 联合查询,哪个效率会更好点?

你这是在说一个SQL问题,使用left join 远远超过 使用in 的人。

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

Label berkaitan:
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan