文章详情页
mysql - 如何减少使用或者不用LEFT JOIN查询?
浏览:133日期:2022-06-13 14:55:38
问题描述
问题解答
回答1:单独查询,使用键值对
回答2:很简单也很实用的一个方案就是建立中间表, 用空间换时间。
另外当数据量大到一定程度情况下,考虑分库分表,可以看看mycat中间件。
回答3:个人建议先一个个表排除看是哪个表影响查询的速度,确定是哪个表之后,然后再根据其做索引优化
回答4:从数据库优化角度出发,最后结果就一个数count(*)大量的关联导致内存消耗跟时间浪费.
给个思路吧:将sql结果做成如下:
最后count(*)等于每一行数量相乘最后相加,即:(数量11*数量12*...*数量16)+(数量21*...*数量26)以减少大量的笛卡尔积.
sql:
select t_for_sale.id, nvl(t1.count1, 0), ...left join (select id, count(*) count1 from t_user group by id) t1 on t1.id=t_for_sale.id....from t_for_sale
相关文章:
1. html5 - 如何实现带阴影的不规则容器?2. javascript - 循环嵌套多个promise应该如何实现?3. mysql优化 - 关于mysql分区4. css - 移动端字体设置问题5. objective-c - iOS开发支付宝和微信支付完成为什么跳转到了之前开发的一个app?6. css3 - rem布局下,用户浏览器的最小字号是12px怎么办?7. vue.js - vue 打包后 nginx 服务端API请求跨域问题无法解决。8. 请教各位大佬,浏览器点 提交实例为什么没有反应9. 前端 - IE9 css兼容问题10. javascript - ionic2 input autofocus 电脑成功,iOS手机键盘不弹出
排行榜
