Rumah pangkalan data tutorial mysql 【MySQL优化】MySQL GROUP BY 操作的优化_MySQL

【MySQL优化】MySQL GROUP BY 操作的优化_MySQL

Jun 01, 2016 pm 01:45 PM
pengoptimuman

bitsCN.com

MySQL GROUP BY 操作的优化
默认情况下, MySQL 在执行 GROUP BY col1 , col2.... 操作的时候,会按照 GROUP BY 字段的顺序进行排序。如果显式包括一个包含相同的列的 ORDER BY 子句,则对 MySQL 的实际执行性能没有什么额外的影响。

如果查询包括 GROUP BY 操作, 但是不需要对结果进行排序,或者对默认的排序结果不满意,希望获得结果后再由程序进一步处理的时候,可以指定 ORDER BY NULL 禁止排序,从而避免排序结果的消耗。

下面介绍的例子对比了开启 / 关闭 GROUP BY 排序的执行计划:

mysql> desc select dep,pos,avg(sal) from employee group by dep,pos G

*************************** 1. row ***************************

id: 1

select_type: SIMPLE

table: employee

type: ALL

possible_keys: NULL

key: NULL

key_len: NULL

ref: NULL

rows: 10

Extra: Using temporary; Using filesort

1 row in set (0.00 sec)

mysql> desc select dep,pos,avg(sal) from employee group by dep,pos order by null G

*************************** 1. row ***************************

id: 1

select_type: SIMPLE

table: employee

type: ALL

possible_keys: NULL

key: NULL

key_len: NULL

ref: NULL

rows: 10

Extra: Using temporary

1 row in set (0.00 sec)

从执行计划可以看到,使用了 ORDER BY NULL 的 SQL 减少了文件排序的步骤,当返回结果集很大时,对于 GROUP BY 的性能是有很大改善的。

bitsCN.com
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

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Perbincangan tentang strategi pengoptimuman gc Golang Perbincangan tentang strategi pengoptimuman gc Golang Mar 06, 2024 pm 02:39 PM

Perbincangan tentang strategi pengoptimuman gc Golang

Pengoptimuman program C++: teknik pengurangan kerumitan masa Pengoptimuman program C++: teknik pengurangan kerumitan masa Jun 01, 2024 am 11:19 AM

Pengoptimuman program C++: teknik pengurangan kerumitan masa

Tafsiran mendalam: Mengapa Laravel lambat seperti siput? Tafsiran mendalam: Mengapa Laravel lambat seperti siput? Mar 07, 2024 am 09:54 AM

Tafsiran mendalam: Mengapa Laravel lambat seperti siput?

Penyahkodan kesesakan prestasi Laravel: Teknik pengoptimuman didedahkan sepenuhnya! Penyahkodan kesesakan prestasi Laravel: Teknik pengoptimuman didedahkan sepenuhnya! Mar 06, 2024 pm 02:33 PM

Penyahkodan kesesakan prestasi Laravel: Teknik pengoptimuman didedahkan sepenuhnya!

Bagaimana untuk mengoptimumkan tetapan dan meningkatkan prestasi selepas menerima komputer Win11 baharu? Bagaimana untuk mengoptimumkan tetapan dan meningkatkan prestasi selepas menerima komputer Win11 baharu? Mar 03, 2024 pm 09:01 PM

Bagaimana untuk mengoptimumkan tetapan dan meningkatkan prestasi selepas menerima komputer Win11 baharu?

Kesesakan prestasi Laravel didedahkan: penyelesaian pengoptimuman didedahkan! Kesesakan prestasi Laravel didedahkan: penyelesaian pengoptimuman didedahkan! Mar 07, 2024 pm 01:30 PM

Kesesakan prestasi Laravel didedahkan: penyelesaian pengoptimuman didedahkan!

Konfigurasi parameter Vivox100s didedahkan: Bagaimana untuk mengoptimumkan prestasi pemproses? Konfigurasi parameter Vivox100s didedahkan: Bagaimana untuk mengoptimumkan prestasi pemproses? Mar 24, 2024 am 10:27 AM

Konfigurasi parameter Vivox100s didedahkan: Bagaimana untuk mengoptimumkan prestasi pemproses?

Bagaimana untuk mengoptimumkan item permulaan sistem WIN7 Bagaimana untuk mengoptimumkan item permulaan sistem WIN7 Mar 26, 2024 pm 06:20 PM

Bagaimana untuk mengoptimumkan item permulaan sistem WIN7

See all articles