mysql 优化
先说说我现在这个项目的情况 再好的数据库设计基本上也避免不了子查询和联合查询。
但是一条普通的查询都要3s的时间,子查询甚至30s还是有些太夸张了。
或许可以把你的表结构贴出来,一起探讨。
用联结查询比较好left join,right join.
联接查询时一条一条去比对,匹配了查询就终结。
select aid,b.name where tb1 a,tb2 b where a.id=b.id 这种是先将tb1和tb2的结果搞成笛卡尔积。
然后在笛卡尔积中筛选a.id=b.id的条目,效率大打折扣。
所以多用left join,right join吧
用联结查询比较好left join,right join.
联接查询时一条一条去比对,匹配了查询就终结。
select aid,b.name where tb1 a,tb2 b where a.id=b.id 这种是先将tb1和tb2的结果搞成笛卡尔积。
然后在笛卡尔积中筛选a.id=b.id的条目,效率大打折扣。
所以多用left join,right join吧
我用联结查询时 先left join 然后再用这些where条件 这个应该不冲突的吧?
合理建表,合理索引。
explain分析一下呢
联结查询有时候也不能完全取消,主要还是看索引建立的合适不合适,看sql有没有合理使用索引
最好还是把你的结构和sql拿出来分析分析
建议跟踪下cpu的使用以及进程之类的
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号