Mysql-G-sql 性能优化(二)

本文探讨了SQL性能下降的常见原因,如查询设计、索引失效、过度join等问题,并详细介绍了四种常见的join类型:左连接、右连接、内连接和全连接。此外,还揭示了程序员预期执行顺序与实际执行顺序的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、sql性能下降的原因

  • 查询语句写的比较差
  • 索引失效:a.单值索引、b.复合索引
  • 关联查询太多join(设计缺陷或不得已的需求)
  • 服务器调优及各个参数设置(缓冲、线程数等)

二、常见的join查询

        1.左连接

               

SELECT <select_list> FROM TableA A  LEFT JOIN  TableB B ON A.Key = B.Key

         2.右连接

                

SELECT <select_list> FROM TableA A RIGHT JOIN TableB B ON A.Key = B.Key 

        3.内连接

                

SELECT <select_list> FROM TableA A INNER JOIN TableB B ON A.Key = B.Key

         4.全连接

        

SELECT <select_list> FROM TableA FULL OUTER JOIN TableB B ON A.Key = B.Key

三、sql执行顺序

-->  程序员认为的执行顺序

SELECT  DISTINCT  

        <select_list>

FROM

        < left_table > < join_type >

JOIN  < right_table >  ON  < join_condition >

WHERE

        < where_condition >

GROUP   BY

        < group_by_list >

HAVING

        < having_condition >

ORDER  BY

        < order_by_condition >

LIMIT  < limit_number >

--> 实际机器读sql的顺序

FROM  < left_table >

ON  < join_condition >

< join_type >  JOIN  < right_table > 

WHERE  < where_condition >

GROUP   BY  < group_by_list >

HAVING  < having_condition >

SELECT   

DISTINCT     <select_list>

ORDER  BY  < order_by_condition >

LIMIT  < limit_number >

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

forward93124

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值