In mysql, you can use the "SELECT" statement and the MAX() function to query the maximum value. This function can return the maximum value in a set of values. The syntax "SELECT MAX(DISTINCT expression) FROM data table name ;".
The operating environment of this tutorial: windows7 system, mysql8 version, Dell G3 computer.
In mysql, you can use the "SELECT" statement and the MAX() function to query the maximum value.
MySQL MAX()
The function returns the maximum value in a set of values. The MAX()
function is very convenient in many queries, such as finding the maximum quantity, the most expensive product, and the maximum payment by a customer.
MAX()
The syntax of the function is as follows:
MAX(DISTINCT expression);
If you add the DISTINCT
operator, the MAX
function returns a different The maximum value of a value, which is the same as the maximum value of all values. This means that the DISTINCT
operator will not have any impact on the MAX
function (it does not matter whether the DISTINCT
operator is used or not).
Please note that the DISTINCT
operator takes effect within other aggregation functions such as COUNT, SUM, and AVG.
MySQL MAX function example
Let’s take a look at the payments
table in the sample database (yiibaidb). Its table structure is as follows -
mysql> desc payments; +----------------+---------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +----------------+---------------+------+-----+---------+-------+ | customerNumber | int(11) | NO | PRI | NULL | | | checkNumber | varchar(50) | NO | PRI | NULL | | | paymentDate | date | NO | | NULL | | | amount | decimal(10,2) | NO | | NULL | | +----------------+---------------+------+-----+---------+-------+ 4 rows in set
To get the maximum payment in the payments
table, you can use the following query:
SELECT MAX(amount) FROM payments;
Execute the above query statement and get the following results-
mysql> SELECT MAX(amount) FROM payments; +-------------+ | MAX(amount) | +-------------+ | 120166.58 | +-------------+ 1 row in set
MySQL MAX function in subquery
To get not only the maximum payment amount, but also other payment information such as customer number, check number and payment date, you can do it in the subquery Use the MAX
function as follows:
SELECT * FROM payments WHERE amount = ( SELECT MAX(amount) FROM payments);
Execute the above query statement and get the following results-
+----------------+-------------+-------------+-----------+ | customerNumber | checkNumber | paymentDate | amount | +----------------+-------------+-------------+-----------+ | 141 | JE105477 | 2015-03-18 | 120166.58 | +----------------+-------------+-------------+-----------+ 1 row in set
How does the above query statement run?
- Subquery returns all maximum payment amounts.
- The outer query retrieves other related payment information whose amount is equal to the maximum amount returned from the subquery.
An alternative to not using the MAX
function is to use the ORDER BY
clause to sort the result set in descending order and use LIMIT
clause gets the first row, query as follows:
SELECT * FROM payments ORDER BY amount DESC LIMIT 1;
Execute the above query statement and get the following results-
+----------------+-------------+-------------+-----------+ | customerNumber | checkNumber | paymentDate | amount | +----------------+-------------+-------------+-----------+ | 141 | JE105477 | 2015-03-18 | 120166.58 | +----------------+-------------+-------------+-----------+ 1 row in set
If you have not created on the amount
column index, the second query executes faster because it checks all rows in the payments
table, whereas the first query checks all rows in the payments
table twice , once in the subquery and once in the outer query. However, if the amount
column is indexed, the first query will execute faster.
MySQL MAX with GROUP BY clause
To find the maximum value for each group, you can do it in SELECT
Use MAX
function and GROUP BY
clause in the statement.
For each customer, query to obtain the maximum payment the customer has paid, you can use the following query:
SELECT customerNumber, MAX(amount) FROM payments GROUP BY customerNumber ORDER BY MAX(amount);
Execute the above query statement and get the following query results-
+----------------+-------------+ | customerNumber | MAX(amount) | +----------------+-------------+ | 219 | 4465.85 | | 198 | 9658.74 | | 381 | 14379.9 | | 103 | 14571.44 | | 473 | 17746.26 | | 362 | 18473.71 | ******* 此处省略一大波数据 ****** | 148 | 105743 | | 124 | 111654.4 | | 141 | 120166.58 | +----------------+-------------+ 98 rows in set
MySQL MAX with HAVING clause
You can use MAX## in the
HAVING clause #Function to add filters to groups based on specified conditions.
For example, the following query finds the maximum payment for each customer; and based on the returned amount, such as the following query statement, only queries for payments exceeding
80000
SELECT customerNumber, MAX(amount) FROM payments GROUP BY customerNumber HAVING MAX(amount) > 80000;
is executed The above query statement yields the following results -
+----------------+-------------+ | customerNumber | MAX(amount) | +----------------+-------------+ | 114 | 82261.22 | | 124 | 111654.4 | | 141 | 120166.58 | | 148 | 105743 | | 167 | 85024.46 | | 239 | 80375.24 | | 321 | 85559.12 | +----------------+-------------+ 7 rows in set[Related recommendations:
mysql video tutorial
]The above is the detailed content of How to query the maximum value in mysql. For more information, please follow other related articles on the PHP Chinese website!

MySQLhandlesconcurrencyusingamixofrow-levelandtable-levellocking,primarilythroughInnoDB'srow-levellocking.ComparedtootherRDBMS,MySQL'sapproachisefficientformanyusecasesbutmayfacechallengeswithdeadlocksandlacksadvancedfeatureslikePostgreSQL'sSerializa

MySQLhandlestransactionseffectivelyusingtheInnoDBengine,supportingACIDpropertiessimilartoPostgreSQLandOracle.1)MySQLusesREPEATABLEREADasthedefaultisolationlevel,whichcanbeadjustedtoREADCOMMITTEDforhigh-trafficscenarios.2)Itoptimizesperformancewithabu

MySQLisbetterforspeedandsimplicity,suitableforwebapplications;PostgreSQLexcelsincomplexdatascenarioswithrobustfeatures.MySQLisidealforquickprojectsandread-heavytasks,whilePostgreSQLispreferredforapplicationsrequiringstrictdataintegrityandadvancedSQLf

MySQL processes data replication through three modes: asynchronous, semi-synchronous and group replication. 1) Asynchronous replication performance is high but data may be lost. 2) Semi-synchronous replication improves data security but increases latency. 3) Group replication supports multi-master replication and failover, suitable for high availability requirements.

The EXPLAIN statement can be used to analyze and improve SQL query performance. 1. Execute the EXPLAIN statement to view the query plan. 2. Analyze the output results, pay attention to access type, index usage and JOIN order. 3. Create or adjust indexes based on the analysis results, optimize JOIN operations, and avoid full table scanning to improve query efficiency.

Using mysqldump for logical backup and MySQLEnterpriseBackup for hot backup are effective ways to back up MySQL databases. 1. Use mysqldump to back up the database: mysqldump-uroot-pmydatabase>mydatabase_backup.sql. 2. Use MySQLEnterpriseBackup for hot backup: mysqlbackup--user=root-password=password--backup-dir=/path/to/backupbackup. When recovering, use the corresponding life

The main reasons for slow MySQL query include missing or improper use of indexes, query complexity, excessive data volume and insufficient hardware resources. Optimization suggestions include: 1. Create appropriate indexes; 2. Optimize query statements; 3. Use table partitioning technology; 4. Appropriately upgrade hardware.

MySQL view is a virtual table based on SQL query results and does not store data. 1) Views simplify complex queries, 2) Enhance data security, and 3) Maintain data consistency. Views are stored queries in databases that can be used like tables, but data is generated dynamically.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

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

MantisBT
Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

SublimeText3 Chinese version
Chinese version, very easy to use

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

SecLists
SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.
