Applying Aggregate Functions and GROUP BY in MySQL
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.

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.

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:

-
COUNT(): count the number of rows -
SUM(): Sum -
AVG(): Find the average value -
MAX()andMIN(): 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.

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;
Scenario 3: Check the sales trends of each month
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!
Hot AI Tools
Undress AI Tool
Undress images for free
Undresser.AI Undress
AI-powered app for creating realistic nude photos
AI Clothes Remover
Online AI tool for removing clothes from photos.
Clothoff.io
AI clothes remover
Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!
Hot Article
Hot Tools
Notepad++7.3.1
Easy-to-use and free code editor
SublimeText3 Chinese version
Chinese version, very easy to use
Zend Studio 13.0.1
Powerful PHP integrated development environment
Dreamweaver CS6
Visual web development tools
SublimeText3 Mac version
God-level code editing software (SublimeText3)
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.
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
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
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?
Aug 14, 2025 pm 05:25 PM
UNIONremovesduplicateswhileUNIONALLkeepsallrowsincludingduplicates;1.UNIONperformsdeduplicationbysortingandcomparingrows,returningonlyuniqueresults,whichmakesitsloweronlargedatasets;2.UNIONALLincludeseveryrowfromeachquerywithoutcheckingforduplicates,
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?
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?
Aug 12, 2025 pm 03:46 PM
TheINoperatorinMySQLchecksifavaluematchesanyinaspecifiedlist,simplifyingmultipleORconditions;itworkswithliterals,strings,dates,andsubqueries,improvesqueryreadability,performswellonindexedcolumns,supportsNOTIN(withcautionforNULLs),andcanbecombinedwith


