Jadual Kandungan
1. Contoh mudah penggunaan kumpulan oleh
2. Kumpulan mengikut analisis prinsip
2.1 menerangkan analisis
2.2 Proses pelaksanaan mudah kumpulan oleh
3. where 和 having的区别
3.1 group by + where 的执行流程
3.2 group by + having 的执行
3.3 同时有where、group by 、having的执行顺序
3.4 where + having 区别总结
4. 使用 group by 注意的问题
4.1 group by一定要配合聚合函数使用嘛?
4.2 group by 后面跟的字段一定要出现在select中嘛。
5. group by的一些优化方案
5.1 group by 后面的字段加索引
5.2 order by null 不用排序
5.3 尽量只使用内存临时表
5.4 使用SQL_BIG_RESULT优化
6. 一个生产慢SQL如何优化
Rumah pangkalan data tutorial mysql Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

Jan 17, 2022 pm 07:28 PM
group by mysql

Bagaimana untuk menggunakan kumpulan oleh dalam MySql? Artikel berikut akan memberi anda analisis mendalam tentang penggunaan kumpulan oleh.

Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

Dalam perkembangan harian, kita sering menggunakan group by. Rakan-rakan yang dihormati, adakah anda tahu bagaimana group by berfungsi? Apakah perbezaan antara group by dan having? Apakah idea pengoptimuman untuk group by? Apakah isu yang perlu diberi perhatian apabila menggunakan group by? Artikel ini akan belajar bersama anda dan mengatasi group by~

  • Contoh mudah menggunakan kumpulan mengikut
  • kumpulan mengikut prinsip kerja
  • kumpulan mengikut mana dan kumpulan mengikut Perbezaan mempunyai
  • kumpulan mengikut idea pengoptimuman
  • kumpulan mengikut nota penggunaan
  • Cara mengoptimumkan SQL pengeluaran yang perlahan

[Cadangan berkaitan: tutorial video mysql]

1. Contoh mudah penggunaan kumpulan oleh

group by biasanya digunakan untuk statistik kumpulan dan logiknya ia menyatakan ialah根据一定的规则,进行分组. Mari kita mulakan dengan contoh mudah dan semak bersama-sama.

Anggapkan jadual pekerja digunakan Struktur jadual adalah seperti berikut:

CREATE TABLE `staff` (
  `id` bigint(11) NOT NULL AUTO_INCREMENT COMMENT '主键id',
  `id_card` varchar(20) NOT NULL COMMENT '身份证号码',
  `name` varchar(64) NOT NULL COMMENT '姓名',
  `age` int(4) NOT NULL COMMENT '年龄',
  `city` varchar(64) NOT NULL COMMENT '城市',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT='员工表';
Salin selepas log masuk

Data inventori jadual adalah seperti berikut:

Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

Kami kini mempunyai keperluan sedemikian: Kira bilangan pekerja di setiap bandar. Pernyataan SQL yang sepadan boleh ditulis seperti ini:

select city ,count(*) as num from staff group by city;
Salin selepas log masuk

Hasil pelaksanaan adalah seperti berikut:

Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

Logik pernyataan SQL ini sangat jelas , tetapi ia Apakah proses pelaksanaan asas?

2. Kumpulan mengikut analisis prinsip

2.1 menerangkan analisis

Mari kita gunakan explain untuk menyemak pelan pelaksanaan

explain select city ,count(*) as num from staff group by city;
Salin selepas log masuk
Salin selepas log masuk

Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

  • Tambahan Using temporary medan ini menunjukkan bahawa jadual sementara digunakan semasa melaksanakan pengumpulan
  • Tambahan Using filesort medan ini Maksudnya menggunakan pengisihan

group by Bagaimanakah 临时表和排序 digunakan? Mari kita lihat proses pelaksanaan SQL ini

2.2 Proses pelaksanaan mudah kumpulan oleh

explain select city ,count(*) as num from staff group by city;
Salin selepas log masuk
Salin selepas log masuk

Mari kita lihat proses pelaksanaan SQL ini

  1. Buat jadual memori sementara dengan dua medan city dan num;
  2. imbas seluruh jadual untuk rekod staff dan keluarkan rekod bandar = 'X' dalam urutan .
  • Nilai sama ada terdapat baris dengan city='X' dalam jadual sementara Jika tidak, masukkan rekod (X,1);
  • Jika terdapat baris dengan city='X' dalam jadual sementara, tambahkan 1 pada nilai nombor baris x; > Isih
  • untuk mendapatkan set hasil dan kembalikan kepada pelanggan.
  1. Rajah pelaksanaan proses ini adalah seperti berikut: city
Apakah pengisihan jadual sementara?

ialah meletakkan medan yang perlu diisih ke dalam penimbal isihan, dan kembali selepas mengisih. Perhatikan di sini, pengisihan dibahagikan kepada Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)Isih medan penuh

dan

isihan rowid

Jika ia , semua medan yang perlu dikembalikan dengan pertanyaan dimasukkan ke dalam , selepas mengisih mengikut medan pengisihan

, kembali terus ke
  • , jika ia 全字段排序, letakkan sahaja medan yang perlu diisih ke dalam sort buffer, dan kemudian kembali ke jadualOperasi dan kemudian kembali.
  • Bagaimana untuk menentukan sama ada hendak menggunakan pengisihan medan penuh atau pengisihan rowid? Dikawal oleh parameter pangkalan data, rowid排序sort buffer
  • Rakan-rakan yang berminat untuk mengetahui lebih lanjut tentang pengisihan boleh membaca artikel saya ini.
  • 3. where 和 having的区别

    • group by + where 的执行流程
    • group by + having 的执行流程
    • 同时有where、group by 、having的执行顺序

    3.1 group by + where 的执行流程

    有些小伙伴觉得上一小节的SQL太简单啦,如果加了where条件之后,并且where条件列加了索引呢,执行流程是怎样

    好的,我们给它加个条件,并且加个idx_age的索引,如下:

    select city ,count(*) as num from staff where age> 30 group by city;
    //加索引
    alter table staff add index idx_age (age);
    Salin selepas log masuk

    再来expain分析一下:

    explain select city ,count(*) as num from staff where age> 30 group by city;
    Salin selepas log masuk

    Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

    从explain 执行计划结果,可以发现查询条件命中了idx_age的索引,并且使用了临时表和排序

    Using index condition:表示索引下推优化,根据索引尽可能的过滤数据,然后再返回给服务器层根据where其他条件进行过滤。这里单个索引为什么会出现索引下推呢?explain出现并不代表一定是使用了索引下推,只是代表可以使用,但是不一定用了。大家如果有想法或者有疑问,可以加我微信讨论哈。

    执行流程如下:

    1、创建内存临时表,表里有两个字段citynum

    2、扫描索引树idx_age,找到大于年龄大于30的主键ID

    3、通过主键ID,回表找到city = 'X'

    • 判断临时表中是否有为 city='X'的行,没有就插入一个记录 (X,1);
    • 如果临时表中有city='X'的行的行,就将x 这一行的num值加 1;

    4、继续重复2,3步骤,找到所有满足条件的数据,

    5、最后根据字段city排序,得到结果集返回给客户端。

    3.2 group by + having 的执行

    如果你要查询每个城市的员工数量,获取到员工数量不低于3的城市,having可以很好解决你的问题,SQL酱紫写:

    select city ,count(*) as num from staff  group by city having num >= 3;
    Salin selepas log masuk

    查询结果如下:

    Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

    having称为分组过滤条件,它对返回的结果集操作。

    3.3 同时有where、group by 、having的执行顺序

    如果一个SQL同时含有where、group by、having子句,执行顺序是怎样的呢。

    比如这个SQL:

    select city ,count(*) as num from staff  where age> 19 group by city having num >= 3;
    Salin selepas log masuk
    • 执行where子句查找符合年龄大于19的员工数据

    • group by子句对员工数据,根据城市分组。

    • group by子句形成的城市组,运行聚集函数计算每一组的员工数量值;

    • 最后用having子句选出员工数量大于等于3的城市组。

    3.4 where + having 区别总结

    • having子句用于分组后筛选,where子句用于条件筛选
    • having一般都是配合group by 和聚合函数一起出现如(count(),sum(),avg(),max(),min())
    • where条件子句中不能使用聚集函数,而having子句就可以。
    • having只能用在group by之后,where执行在group by之前

    4. 使用 group by 注意的问题

    使用group by 主要有这几点需要注意:

    • group by一定要配合聚合函数一起使用嘛?
    • group by的字段一定要出现在select中嘛
    • group by导致的慢SQL问题

    4.1 group by一定要配合聚合函数使用嘛?

    group by 就是分组统计的意思,一般情况都是配合聚合函数 如(count(),sum(),avg(),max(),min())一起使用。

    • count() 数量
    • sum() 总和
    • avg() 平均
    • max() 最大值
    • min() 最小值

    如果没有配合聚合函数使用可以吗?

    我用的是Mysql 5.7 ,是可以的。不会报错,并且返回的是,分组的第一行数据。

    比如这个SQL:

    select city,id_card,age from staff group by  city;
    Salin selepas log masuk

    查询结果是

    Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

    大家对比看下,返回的就是每个分组的第一条数据

    Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

    当然,平时大家使用的时候,group by还是配合聚合函数使用的,除非一些特殊场景,比如你想去重,当然去重用distinct也是可以的。

    4.2 group by 后面跟的字段一定要出现在select中嘛。

    不一定,比如以下SQL:

    select max(age)  from staff group by city;
    Salin selepas log masuk

    执行结果如下:

    Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

    分组字段city不在select 后面,并不会报错。当然,这个可能跟不同的数据库,不同的版本有关吧。大家使用的时候,可以先验证一下就好。有一句话叫做,纸上得来终觉浅,绝知此事要躬行

    4.3 <span style="font-size: 16px;">group by</span>导致的慢SQL问题

    到了最重要的一个注意问题啦,group by使用不当,很容易就会产生慢SQL 问题。因为它既用到临时表,又默认用到排序。有时候还可能用到磁盘临时表

    • 如果执行过程中,会发现内存临时表大小到达了上限(控制这个上限的参数就是tmp_table_size),会把内存临时表转成磁盘临时表
    • 如果数据量很大,很可能这个查询需要的磁盘临时表,就会占用大量的磁盘空间。

    这些都是导致慢SQL的x因素,我们一起来探讨优化方案哈。

    5. group by的一些优化方案

    从哪些方向去优化呢?

    • 方向1: 既然它默认会排序,我们不给它排是不是就行啦。
    • 方向2:既然临时表是影响group by性能的X因素,我们是不是可以不用临时表?

    我们一起来想下,执行group by语句为什么需要临时表呢?group by的语义逻辑,就是统计不同的值出现的个数。如果这个这些值一开始就是有序的,我们是不是直接往下扫描统计就好了,就不用临时表来记录并统计结果啦?

    • group by 后面的字段加索引
    • order by null 不用排序
    • 尽量只使用内存临时表
    • 使用SQL_BIG_RESULT

    5.1 group by 后面的字段加索引

    如何保证group by后面的字段数值一开始就是有序的呢?当然就是加索引啦。

    我们回到一下这个SQL

    select city ,count(*) as num from staff where age= 19 group by city;
    Salin selepas log masuk

    它的执行计划

    Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

    如果我们给它加个联合索引idx_age_city(age,city)

    alter table staff add index idx_age_city(age,city);
    Salin selepas log masuk

    再去看执行计划,发现既不用排序,也不需要临时表啦。

    1Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

    加合适的索引是优化group by最简单有效的优化方式。

    5.2 order by null 不用排序

    并不是所有场景都适合加索引的,如果碰上不适合创建索引的场景,我们如何优化呢?

    如果你的需求并不需要对结果集进行排序,可以使用order by null

    select city ,count(*) as num from staff group by city order by null
    Salin selepas log masuk

    执行计划如下,已经没有filesort

    1Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

    5.3 尽量只使用内存临时表

    如果group by需要统计的数据不多,我们可以尽量只使用内存临时表;因为如果group by 的过程因为数据放不下,导致用到磁盘临时表的话,是比较耗时的。因此可以适当调大tmp_table_size参数,来避免用到磁盘临时表

    5.4 使用SQL_BIG_RESULT优化

    如果数据量实在太大怎么办呢?总不能无限调大tmp_table_size吧?但也不能眼睁睁看着数据先放到内存临时表,随着数据插入发现到达上限,再转成磁盘临时表吧?这样就有点不智能啦。

    因此,如果预估数据量比较大,我们使用SQL_BIG_RESULT 这个提示直接用磁盘临时表。MySQl优化器发现,磁盘临时表是B+树存储,存储效率不如数组来得高。因此会直接用数组来存

    示例SQl如下:

    select SQL_BIG_RESULT city ,count(*) as num from staff group by city;
    Salin selepas log masuk

    执行计划的Extra字段可以看到,执行没有再使用临时表,而是只有排序

    1Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan)

    执行流程如下:

    • 初始化 sort_buffer,放入city字段;

    • 扫描表staff,依次取出city的值,存入 sort_buffer 中;

    • 扫描完成后,对 sort_buffer的city字段做排序

    • 排序完成后,就得到了一个有序数组。

    • 根据有序数组,统计每个值出现的次数。

    6. 一个生产慢SQL如何优化

    最近遇到个生产慢SQL,跟group by相关的,给大家看下怎么优化哈。

    表结构如下:

    CREATE TABLE `staff` (
      `id` bigint(11) NOT NULL AUTO_INCREMENT COMMENT &#39;主键id&#39;,
      `id_card` varchar(20) NOT NULL COMMENT &#39;身份证号码&#39;,
      `name` varchar(64) NOT NULL COMMENT &#39;姓名&#39;,
      `status` varchar(64) NOT NULL COMMENT &#39;Y-已激活 I-初始化 D-已删除 R-审核中&#39;,
      `age` int(4) NOT NULL COMMENT &#39;年龄&#39;,
      `city` varchar(64) NOT NULL COMMENT &#39;城市&#39;,
      `enterprise_no` varchar(64) NOT NULL COMMENT &#39;企业号&#39;,
      `legal_cert_no` varchar(64) NOT NULL COMMENT &#39;法人号码&#39;,
      PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=15 DEFAULT CHARSET=utf8 COMMENT=&#39;员工表&#39;;
    Salin selepas log masuk

    查询的SQL是这样的:

    select * from t1 where status = #{status} group by #{legal_cert_no}
    Salin selepas log masuk

    我们先不去探讨这个SQL的=是否合理。如果就是这么个SQL,你会怎么优化呢?有想法的小伙伴可以留言讨论哈,也可以加我微信加群探讨。如果你觉得文章那里写得不对,也可以提出来哈,一起进步,加油呀

    更多编程相关知识,请访问:编程入门!!

    Atas ialah kandungan terperinci Ketahui lebih lanjut tentang cara menggunakan kumpulan oleh dalam MySql? (Penjelasan terperinci penggunaan). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

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

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat 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)

Cara membuka phpmyadmin Cara membuka phpmyadmin Apr 10, 2025 pm 10:51 PM

Anda boleh membuka phpmyadmin melalui langkah -langkah berikut: 1. Log masuk ke panel kawalan laman web; 2. Cari dan klik ikon phpmyadmin; 3. Masukkan kelayakan MySQL; 4. Klik "Login".

MySQL: Pengenalan kepada pangkalan data paling popular di dunia MySQL: Pengenalan kepada pangkalan data paling popular di dunia Apr 12, 2025 am 12:18 AM

MySQL adalah sistem pengurusan pangkalan data relasi sumber terbuka, terutamanya digunakan untuk menyimpan dan mengambil data dengan cepat dan boleh dipercayai. Prinsip kerjanya termasuk permintaan pelanggan, resolusi pertanyaan, pelaksanaan pertanyaan dan hasil pulangan. Contoh penggunaan termasuk membuat jadual, memasukkan dan menanyakan data, dan ciri -ciri canggih seperti Operasi Join. Kesalahan umum melibatkan sintaks SQL, jenis data, dan keizinan, dan cadangan pengoptimuman termasuk penggunaan indeks, pertanyaan yang dioptimumkan, dan pembahagian jadual.

Tempat Mysql: Pangkalan Data dan Pengaturcaraan Tempat Mysql: Pangkalan Data dan Pengaturcaraan Apr 13, 2025 am 12:18 AM

Kedudukan MySQL dalam pangkalan data dan pengaturcaraan sangat penting. Ia adalah sistem pengurusan pangkalan data sumber terbuka yang digunakan secara meluas dalam pelbagai senario aplikasi. 1) MySQL menyediakan fungsi penyimpanan data, organisasi dan pengambilan data yang cekap, sistem sokongan web, mudah alih dan perusahaan. 2) Ia menggunakan seni bina pelanggan-pelayan, menyokong pelbagai enjin penyimpanan dan pengoptimuman indeks. 3) Penggunaan asas termasuk membuat jadual dan memasukkan data, dan penggunaan lanjutan melibatkan pelbagai meja dan pertanyaan kompleks. 4) Soalan -soalan yang sering ditanya seperti kesilapan sintaks SQL dan isu -isu prestasi boleh disahpepijat melalui arahan jelas dan log pertanyaan perlahan. 5) Kaedah pengoptimuman prestasi termasuk penggunaan indeks rasional, pertanyaan yang dioptimumkan dan penggunaan cache. Amalan terbaik termasuk menggunakan urus niaga dan preparedStatemen

Mengapa menggunakan mysql? Faedah dan kelebihan Mengapa menggunakan mysql? Faedah dan kelebihan Apr 12, 2025 am 12:17 AM

MySQL dipilih untuk prestasi, kebolehpercayaan, kemudahan penggunaan, dan sokongan komuniti. 1.MYSQL Menyediakan fungsi penyimpanan dan pengambilan data yang cekap, menyokong pelbagai jenis data dan operasi pertanyaan lanjutan. 2. Mengamalkan seni bina pelanggan-pelayan dan enjin penyimpanan berganda untuk menyokong urus niaga dan pengoptimuman pertanyaan. 3. Mudah digunakan, menyokong pelbagai sistem operasi dan bahasa pengaturcaraan. 4. Mempunyai sokongan komuniti yang kuat dan menyediakan sumber dan penyelesaian yang kaya.

Cara menyambung ke pangkalan data Apache Cara menyambung ke pangkalan data Apache Apr 13, 2025 pm 01:03 PM

Apache menyambung ke pangkalan data memerlukan langkah -langkah berikut: Pasang pemacu pangkalan data. Konfigurasikan fail web.xml untuk membuat kolam sambungan. Buat sumber data JDBC dan tentukan tetapan sambungan. Gunakan API JDBC untuk mengakses pangkalan data dari kod Java, termasuk mendapatkan sambungan, membuat kenyataan, parameter mengikat, melaksanakan pertanyaan atau kemas kini, dan hasil pemprosesan.

Cara Memulakan MySQL oleh Docker Cara Memulakan MySQL oleh Docker Apr 15, 2025 pm 12:09 PM

Proses memulakan MySQL di Docker terdiri daripada langkah -langkah berikut: Tarik imej MySQL untuk membuat dan memulakan bekas, tetapkan kata laluan pengguna root, dan memetakan sambungan pengesahan port Buat pangkalan data dan pengguna memberikan semua kebenaran ke pangkalan data

Peranan MySQL: Pangkalan Data dalam Aplikasi Web Peranan MySQL: Pangkalan Data dalam Aplikasi Web Apr 17, 2025 am 12:23 AM

Peranan utama MySQL dalam aplikasi web adalah untuk menyimpan dan mengurus data. 1.MYSQL dengan cekap memproses maklumat pengguna, katalog produk, rekod urus niaga dan data lain. 2. Melalui pertanyaan SQL, pemaju boleh mengekstrak maklumat dari pangkalan data untuk menghasilkan kandungan dinamik. 3.MYSQL berfungsi berdasarkan model klien-pelayan untuk memastikan kelajuan pertanyaan yang boleh diterima.

CentOS memasang MySQL CentOS memasang MySQL Apr 14, 2025 pm 08:09 PM

Memasang MySQL pada CentOS melibatkan langkah -langkah berikut: Menambah sumber MySQL YUM yang sesuai. Jalankan YUM Pasang Perintah MySQL-Server untuk memasang pelayan MySQL. Gunakan perintah mysql_secure_installation untuk membuat tetapan keselamatan, seperti menetapkan kata laluan pengguna root. Sesuaikan fail konfigurasi MySQL seperti yang diperlukan. Tune parameter MySQL dan mengoptimumkan pangkalan data untuk prestasi.

See all articles