suchen
HeimDatenbankMySQL-TutorialSo gruppieren und summieren Sie in MySQL

In MySQL können Sie die SELECT-Anweisung mit der SUM()-Funktion und „GROUP BY“ verwenden, um eine Gruppensummierung durchzuführen. Die Syntax lautet „SELECT query field SUM (summation field) AS field FROM table name WHERE condition GROUP BY group field eins, Gruppierungsfeld zwei;".

So gruppieren und summieren Sie in MySQL

Die Betriebsumgebung dieses Tutorials: Windows10-System, MySQL8.0.22-Version, Dell G3-Computer.

So führen Sie eine Gruppensumme in MySQL durch

In MySQL können Sie

SELECT 查询字段 SUM(求和字段) AS 字段 FROM 表名 WHERE 条件 GROUP BY 分组字段一,分组字段二;

verwenden, um eine Gruppensumme durchzuführen.

Beispiele sind wie folgt:

1) count() ermittelt die Anzahl der Zeilen in einer bestimmten Spalte

Es ist leicht zu verstehen, dass count(column name) die Anzahl der Zeilen in einer bestimmten Spalte ermittelt. Es ist zu beachten, dass diese Spalte nicht leer ist. Die Anzahl der Wertezeilen. Beispiel:

>-- Fragen Sie ab, wie viele Lehrer es gibt.

So gruppieren und summieren Sie in MySQL

>-- Fragen Sie ab, wie viele Zeilen es in der Lehrertabelle gibt SELECT COUNT(*) FROM teacher;

So gruppieren und summieren Sie in MySQL

Wenn die Spalte doppelte Werte enthält, zählen wirmöchten die doppelten Werte nicht zählen, was sollen wir tun? Wir können Distinct verwenden, um Folgendes zu lösen:

-- 查询成绩表里共有几个学生的成绩
SELECT COUNT(DISTINCT 学号) FROM score;

So gruppieren und summieren Sie in MySQL

2) sum() summiert die Daten in einer bestimmten Spalte.

Sum summiert die Werte in einer bestimmten Spalte und kann nur die Werte berechnen. Beispiel:

--  对所有成绩求和
SELECT SUM(成绩) FROM score;

So gruppieren und summieren Sie in MySQL

3) avg() findet den Durchschnitt einer bestimmten Wertespalte

Ebenso kann die Berechnung des Durchschnitts nur für numerische Werte erfolgen:

-- 对所有成绩求平均值
SELECT AVG(成绩) FROM score;

So gruppieren und summieren Sie in MySQL

4) max() findet den Maximalwert einer bestimmten Datenspalte und min() findet den Minimalwert einer bestimmten Datenspalte

-- 获取所有成绩中的最大成绩
SELECT MAX(成绩),MIN(成绩) FROM score;

So gruppieren und summieren Sie in MySQL

Group

In der Frage haben wir erwähnt, dass wir es wissen müssen die durchschnittliche Punktzahl jedes Fachs, dann müssen wir eine Gruppierung vornehmen.

In SQL kann die Anweisung „group by“ die Ergebnismenge nach einer oder mehreren Spalten gruppieren. Beispiel:

So gruppieren und summieren Sie in MySQL

-- 计算每一科课程的平均成绩
SELECT 课程号,AVG(成绩) FROM score GROUP BY 课程号;

So gruppieren und summieren Sie in MySQL

Im vorherigen Artikel haben wir die Ausführungsreihenfolge von SQL-Anweisungen kurz vorgestellt: Führen Sie zuerst die Tabelle aus, aus der Daten abgerufen werden sollen, und führen Sie dann die Select-Anweisung aus Beginnen Sie mit

Holen Sie sich die Daten aus der Bewertungstabelle, gruppieren Sie die Daten mithilfe der Anweisung „Gruppe nach“ und berechnen Sie dann „count()“ für die gruppierten Ergebnisse Treten Sie an einen Tisch

.

Bedingungen für die Gruppierungsbedingungen angeben

In der ersten Frage müssen wir „die durchschnittliche Punktzahl jedes Fachs berechnen und feststellen, dass die durchschnittliche Punktzahl größer oder gleich 80 Punkten ist“. die Berechnung der durchschnittlichen Punktzahl eines Probanden pro Tag. Um die Bedingung für die durchschnittliche Punktzahl festzulegen: „größer oder gleich 80 Punkte“

, verwenden wir die

have-Klausel

.

Having-Klausel und Where-Klausel wählen beide bedingt Daten aus. Der Unterschied besteht darin, dass where nicht mit Zusammenfassungsfunktionen verwendet werden kann.

So gruppieren und summieren Sie in MySQL

-- 计算平均成绩大于等于80分的课程;
SELECT 课程号,AVG(成绩) FROM score GROUP BY 课程号 HAVING AVG(成绩)>=80;
Bedeutet das, dass die Reihenfolge der Have-Klausel auch vor der Zusammenfassung ausgewählter Ergebnisse steht? Ja, die Have-Klausel legt Bedingungen für die Gruppierungsergebnisse von „group by“ fest, z. B. das Erfordernis einer Punktzahl größer oder gleich 80. Nach dem Herausfiltern der Ergebnisse werden die Ergebnisse zusammengefasst.

-- 对教师表根据教师姓名排序
SELECT * FROM teacher ORDER BY 教师姓名;

So gruppieren und summieren Sie in MySQLWir haben festgestellt, dass der Nullwert Null an erster Stelle steht, also:

Wenn die Spalten mit Nullwerten sortiert werden, steht der Nullwert Null am Anfang,

Wenn die Datenmenge groß ist, möchten Sie den Nullwert sehen. In diesem Fall können Sie diese Sortierung verwenden. So gruppieren und summieren Sie in MySQL

另外,在补充一个limit语句从查询结果中取出指定行,比如,我们如果从刚才的查询结果中只取第一行:

-- 计算平均成绩大于等于80分的课程并根据成绩降序排,并获取第一行
SELECT 课程号,AVG(成绩) FROM score GROUP BY 课程号 HAVING AVG(成绩)>=80 ORDER BY AVG(成绩) DESC LIMIT 1;

So gruppieren und summieren Sie in MySQL

接下来我们进行一个总结。

用SQL解决业务问题分析思路

简单来说:明确问题,将问题翻译成大白话,逐步进行拆解,并写出分析思路和对应的SQL思路。

1) 明确问题,将问题翻译成大白话:

“计算各科的平均成绩并且得出平均成绩大于等于80分的课程并降序排列”翻译成大白话就是:

“计算每一门课程平均成绩,然后根据得出的结果,进行大于等于80分的条件查询,对查询结果进行降序排列”。

2) 逐步进行拆解,并写出分析思路和对应的SQL思路:

① 对课程号进行分组,计算每一门课程的平均成绩;

② 对①的结果指定条件“>=80”;

③ 对②的结果进行降序排列;

我们可以把拆解后的思路套用到下方的公式中:

select 查询结果
from 从那张表中查找数据
where 查询条件(运算符、模糊查询)
group by 分组(每个)
having 对分组结果指定条件
order by 对查询结果排序
limit 从查询结果中取出指定行;

试一下吧:

select 查询结果[课程号,avg(成绩)]
from 从那张表中查找数据[成绩表score]
where 查询条件(运算符、模糊查询)[No]
group by 分组(每个)[课程号]
having 对分组结果指定条件[avg(成绩)>=80]
order by 对查询结果排序[avg(成绩)desc]
limit 从查询结果中取出指定行;[No]

这样子,问题是不是就迎刃而解呢?

推荐学习:mysql视频教程

Das obige ist der detaillierte Inhalt vonSo gruppieren und summieren Sie in MySQL. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Wie geht MySQL mit der Datenreplikation um?Wie geht MySQL mit der Datenreplikation um?Apr 28, 2025 am 12:25 AM

MySQL verarbeitet die Datenreplikation durch drei Modi: Asynchron, halbsynchron und Gruppenreplikation. 1) Die asynchrone Replikationsleistung ist hoch, die Daten können jedoch verloren gehen. 2) Die halbsynchrone Replikation verbessert die Datensicherheit, erhöht jedoch die Latenz. 3) Die Gruppenreplikation unterstützt die Replikation und das Failover mit mehreren Master, die für Anforderungen an hoher Verfügbarkeit geeignet sind.

Wie können Sie die Erklärungserklärung verwenden, um die Abfrageleistung zu analysieren?Wie können Sie die Erklärungserklärung verwenden, um die Abfrageleistung zu analysieren?Apr 28, 2025 am 12:24 AM

Die Erklärungserklärung kann verwendet werden, um die SQL -Abfrageleistung zu analysieren und zu verbessern. 1. Führen Sie die Erklärung zur Erklärung aus, um den Abfrageplan anzuzeigen. 2. Analysieren Sie die Ausgabeergebnisse, achten Sie auf den Zugriffstyp, die Indexverwendung und den Verbindung der Reihenfolge. 3. Erstellen oder passen Sie die Indizes anhand der Analyseergebnisse an, optimieren Sie die Join -Operationen und vermeiden Sie die volle Tabellen -Scan, um die Effizienz der Abfrage zu verbessern.

Wie können Sie eine MySQL -Datenbank wiederherstellen und wiederherstellen?Wie können Sie eine MySQL -Datenbank wiederherstellen und wiederherstellen?Apr 28, 2025 am 12:23 AM

Die Verwendung von MySQldump für logische Sicherungen und MySQLenterPriseBackups für Hot Backup ist effektive Möglichkeiten, um MySQL -Datenbanken zu sichern. 1. Verwenden Sie MySQldump, um die Datenbank zu sichern: mysqldump-uroot-pmydatabase> mydatabase_backup.sql. 2. Verwenden Sie MySQLenterPriseBackup für Hot Backup: Mysqlbackup-User = Root-Password = Passwort-Backup-Dir =/path/to/backupbackup. Verwenden Sie bei der Wiederherstellung das entsprechende Leben

Was sind einige häufige Ursachen für langsame Abfragen in MySQL?Was sind einige häufige Ursachen für langsame Abfragen in MySQL?Apr 28, 2025 am 12:18 AM

Die Hauptgründe für die langsame MySQL -Abfrage sind fehlende oder unsachgemäße Verwendung von Indizes, Komplexität der Abfrage, übermäßiges Datenvolumen und unzureichende Hardware -Ressourcen. Zu den Optimierungsvorschlägen gehören: 1. Erstellen Sie geeignete Indizes; 2. Optimieren Sie Abfrageanweisungen; 3.. Verwenden Sie die Tabellenpartitionierungstechnologie; 4.. Angemessene Hardware upgraden.

Was sind Ansichten in MySQL?Was sind Ansichten in MySQL?Apr 28, 2025 am 12:04 AM

MySQL View ist eine virtuelle Tabelle, die auf SQL -Abfrageergebnissen basiert und keine Daten speichert. 1) Ansichten vereinfachen komplexe Abfragen, 2) die Datensicherheit verbessern und 3) die Datenkonsistenz beibehalten. Ansichten sind Abfragen in Datenbanken, die wie Tabellen verwendet werden können, aber Daten werden dynamisch generiert.

Was sind die Unterschiede in der Syntax zwischen MySQL und anderen SQL -Dialekten?Was sind die Unterschiede in der Syntax zwischen MySQL und anderen SQL -Dialekten?Apr 27, 2025 am 12:26 AM

MySQLDIFFERSFROMOTHERQLDIALCTSINSYNTAXFORLIMIT, Auto-Increment, StringComparison, Unterabfragen und Performanceanalyse.1) Mysqluse Slimit, whileqlServerusSestopandorakelSrownum.2) Mysql'Sauto_incrementContrastswithpostgresql'Sserialandoracle'ssequencandt

Was ist MySQL Partitioning?Was ist MySQL Partitioning?Apr 27, 2025 am 12:23 AM

Die MySQL -Partitionierung verbessert die Leistung und vereinfacht die Wartung. 1) Teilen Sie große Tabellen nach bestimmten Kriterien (z. B. Datumsbereichen) in kleine Stücke, 2) Daten in unabhängige Dateien physikalisch unterteilen, 3) MySQL kann sich auf verwandte Partitionen konzentrieren, wenn Sie abfragen, 4) Abfragoptimierer kann nicht verwandte Partitionen überspringen, 5) Die Auswahl der richtigen Partitionsstrategie und die regelmäßige Wartung des Schlüssels ist der Schlüssel.

Wie gewähren und widerrufen Sie Privilegien in MySQL?Wie gewähren und widerrufen Sie Privilegien in MySQL?Apr 27, 2025 am 12:21 AM

Wie kann man Berechtigungen in MySQL erteilen und widerrufen? 1. Verwenden Sie die Stipendienerklärung, um Berechtigungen wie GrantAllPrivileGesAndatabase_Name.to'username'@'host '; 2. Verwenden Sie die Revoke -Erklärung, um Berechtigungen wie RevokeAllPrivileGeDatabase_Name.From'username'@'host 'zu widerrufen, um eine rechtzeitige Kommunikation von Genehmigungsänderungen zu gewährleisten.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

mPDF

mPDF

mPDF ist eine PHP-Bibliothek, die PDF-Dateien aus UTF-8-codiertem HTML generieren kann. Der ursprüngliche Autor, Ian Back, hat mPDF geschrieben, um PDF-Dateien „on the fly“ von seiner Website auszugeben und verschiedene Sprachen zu verarbeiten. Es ist langsamer und erzeugt bei der Verwendung von Unicode-Schriftarten größere Dateien als Originalskripte wie HTML2FPDF, unterstützt aber CSS-Stile usw. und verfügt über viele Verbesserungen. Unterstützt fast alle Sprachen, einschließlich RTL (Arabisch und Hebräisch) und CJK (Chinesisch, Japanisch und Koreanisch). Unterstützt verschachtelte Elemente auf Blockebene (wie P, DIV),

WebStorm-Mac-Version

WebStorm-Mac-Version

Nützliche JavaScript-Entwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung