Table of Contents
What is an aggregate function?
What does GROUP BY do?
Common misunderstandings and precautions
Don't miss GROUP BY
GROUP BY Multiple Fields
HAVING is used after aggregation
Examples of practical application scenarios
Scenario 1: Statistics the quantity of products under each category
Scenario 2: Find the top 5 users with the most orders
Scenario 3: Check the sales trends of each month
Home Database Mysql Tutorial Applying Aggregate Functions and GROUP BY in MySQL

Applying Aggregate Functions and GROUP BY in MySQL

Jul 12, 2025 am 02:19 AM
mysql group by

The aggregation function is used to perform calculations on a set of values ​​and return a single value. Common ones include COUNT, SUM, AVG, MAX, and MIN; GROUP BY groups data by one or more columns and applies an aggregation function to each group. For example, GROUP BY user_id is required to count the total order amount of each user; SELECT user_id, SUM(amount) FROM orders GROUP BY user_id; non-aggregated fields must appear in GROUP BY; multiple fields can be used for multi-condition grouping; HAVING is used instead of WHERE after grouping; application scenarios such as counting the number of classified products, maximum order users, monthly sales trends, etc. Mastering these can effectively solve data statistics problems.

Applying Aggregate Functions and GROUP BY in MySQL

In MySQL query, when we need to count and summarize the data, aggregate functions (such as COUNT , SUM , AVG , MAX , MIN ) come in handy. But having an aggregation function alone is not enough. Many times we need to group it by a certain field before doing statistics. At this time, we must use GROUP BY in conjunction with it.

Applying Aggregate Functions and GROUP BY in MySQL

What is an aggregate function?

An aggregate function is a function that performs calculations on a set of values ​​and returns a single value. Common ones include:

Applying Aggregate Functions and GROUP BY in MySQL
  • COUNT() : count the number of rows
  • SUM() : Sum
  • AVG() : Find the average value
  • MAX() and MIN() : Find the maximum or minimum value

For example, if you want to know the total amount of all orders in a certain order table, you can use:

 SELECT SUM(amount) FROM orders;

This adds up amount fields of the entire table and outputs a total number. But what if you want to know the total order amount for each user? GROUP BY is needed at this time.

Applying Aggregate Functions and GROUP BY in MySQL

What does GROUP BY do?

The function of GROUP BY is to group data by one or more columns, and then apply an aggregate function to each group separately.

For example, suppose you have a user order table orders with user_id and amount fields. If you want to know the total order amount of each user, you can write it like this:

 SELECT user_id, SUM(amount) AS total_amount
FROM orders
GROUP BY user_id;

The meaning of this statement is: grouped by user_id , each group of data is performed once SUM(amount) operation, and finally the total amount of each user is returned.

It should be noted that non-aggregated fields that appear in SELECT generally need to appear after GROUP BY . Otherwise, errors may occur or results may be unpredictable, especially if SQL mode ONLY_FULL_GROUP_BY is enabled.


Common misunderstandings and precautions

Don't miss GROUP BY

Many beginners make this mistake:

 SELECT user_id, SUM(amount)
FROM orders;

This statement will report an error in some database systems because user_id is not aggregated and does not appear in GROUP BY clause.

GROUP BY Multiple Fields

If you want to count by user and order year, you can write this:

 SELECT user_id, YEAR(order_date), SUM(amount)
FROM orders
GROUP BY user_id, YEAR(order_date);

HAVING is used after aggregation

If you want to filter out users whose "total amount is greater than 1000", you cannot use WHERE , but HAVING :

 SELECT user_id, SUM(amount) AS total
FROM orders
GROUP BY user_id
HAVING total > 1000;

WHERE filters rows before grouping, while HAVING filters the results after grouping.


Examples of practical application scenarios

Scenario 1: Statistics the quantity of products under each category

 SELECT category_id, COUNT(*) AS product_count
FROM products
GROUP BY category_id;

Scenario 2: Find the top 5 users with the most orders

 SELECT user_id, COUNT(*) AS order_count
FROM orders
GROUP BY user_id
ORDER BY order_count DESC
LIMIT 5;
 SELECT DATE_FORMAT(order_date, '%Y-%m') AS month, SUM(amount) AS total_sales
FROM orders
GROUP BY month
ORDER BY month;

Basically that's it. Mastering the combination of aggregate functions and GROUP BY can help you solve most data statistics problems. Although the syntax is not complicated, it is easy to ignore some details in actual queries, such as field omissions, misuse of WHERE , etc., and you can become proficient after practicing a few more times.

The above is the detailed content of Applying Aggregate Functions and GROUP BY in MySQL. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How to add a primary key to an existing table in MySQL? How to add a primary key to an existing table in MySQL? Aug 12, 2025 am 04:11 AM

To add a primary key to an existing table, use the ALTERTABLE statement with the ADDPRIMARYKEY clause. 1. Ensure that the target column has no NULL value, no duplication and is defined as NOTNULL; 2. The single-column primary key syntax is ALTERTABLE table name ADDPRIMARYKEY (column name); 3. The multi-column combination primary key syntax is ALTERTABLE table name ADDPRIMARYKEY (column 1, column 2); 4. If the column allows NULL, you must first execute MODIFY to set NOTNULL; 5. Each table can only have one primary key, and the old primary key must be deleted before adding; 6. If you need to increase it yourself, you can use MODIFY to set AUTO_INCREMENT. Ensure data before operation

Explain database indexing strategies (e.g., B-Tree, Full-text) for a MySQL-backed PHP application. Explain database indexing strategies (e.g., B-Tree, Full-text) for a MySQL-backed PHP application. Aug 13, 2025 pm 02:57 PM

B-TreeindexesarebestformostPHPapplications,astheysupportequalityandrangequeries,sorting,andareidealforcolumnsusedinWHERE,JOIN,orORDERBYclauses;2.Full-Textindexesshouldbeusedfornaturallanguageorbooleansearchesontextfieldslikearticlesorproductdescripti

How to back up a database in MySQL How to back up a database in MySQL Aug 11, 2025 am 10:40 AM

Using mysqldump is the most common and effective way to back up MySQL databases. It can generate SQL scripts containing table structure and data. 1. The basic syntax is: mysqldump-u[user name]-p[database name]>backup_file.sql. After execution, enter the password to generate a backup file. 2. Back up multiple databases with --databases option: mysqldump-uroot-p--databasesdb1db2>multiple_dbs_backup.sql. 3. Back up all databases with --all-databases: mysqldump-uroot-p

How to change the GROUP_CONCAT separator in MySQL How to change the GROUP_CONCAT separator in MySQL Aug 22, 2025 am 10:58 AM

You can customize the separator by using the SEPARATOR keyword in the GROUP_CONCAT() function; 1. Use SEPARATOR to specify a custom separator, such as SEPARATOR'; 'The separator can be changed to a semicolon and plus space; 2. Common examples include using the pipe character '|', space'', line break character '\n' or custom string '->' as the separator; 3. Note that the separator must be a string literal or expression, and the result length is limited by the group_concat_max_len variable, which can be adjusted by SETSESSIONgroup_concat_max_len=10000; 4. SEPARATOR is optional

What is the difference between UNION and UNION ALL in MySQL? What is the difference between UNION and UNION ALL in MySQL? Aug 14, 2025 pm 05:25 PM

UNIONremovesduplicateswhileUNIONALLkeepsallrowsincludingduplicates;1.UNIONperformsdeduplicationbysortingandcomparingrows,returningonlyuniqueresults,whichmakesitsloweronlargedatasets;2.UNIONALLincludeseveryrowfromeachquerywithoutcheckingforduplicates,

How to lock tables in MySQL How to lock tables in MySQL Aug 15, 2025 am 04:04 AM

The table can be locked manually using LOCKTABLES. The READ lock allows multiple sessions to read but cannot be written. The WRITE lock provides exclusive read and write permissions for the current session and other sessions cannot read and write. 2. The lock is only for the current connection. Execution of STARTTRANSACTION and other commands will implicitly release the lock. After locking, it can only access the locked table; 3. Only use it in specific scenarios such as MyISAM table maintenance and data backup. InnoDB should give priority to using transaction and row-level locks such as SELECT...FORUPDATE to avoid performance problems; 4. After the operation is completed, UNLOCKTABLES must be explicitly released, otherwise resource blockage may occur.

How to select data from a table in MySQL? How to select data from a table in MySQL? Aug 19, 2025 pm 01:47 PM

To select data from MySQL table, you should use SELECT statement, 1. Use SELECTcolumn1, column2FROMtable_name to obtain the specified column, or use SELECT* to obtain all columns; 2. Use WHERE clause to filter rows, such as SELECTname, ageFROMusersWHEREage>25; 3. Use ORDERBY to sort the results, such as ORDERBYageDESC, representing descending order of age; 4. Use LIMIT to limit the number of rows, such as LIMIT5 to return the first 5 rows, or use LIMIT10OFFSET20 to implement paging; 5. Use AND, OR and parentheses to combine

How to use the IN operator in MySQL? How to use the IN operator in MySQL? Aug 12, 2025 pm 03:46 PM

TheINoperatorinMySQLchecksifavaluematchesanyinaspecifiedlist,simplifyingmultipleORconditions;itworkswithliterals,strings,dates,andsubqueries,improvesqueryreadability,performswellonindexedcolumns,supportsNOTIN(withcautionforNULLs),andcanbecombinedwith

See all articles