本篇內容介紹了“mysql如何查詢最大值”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
在mysql中,可以利用“SELECT”語句和MAX()函數來查詢最大值,該函數可返回一組值中的最大值,語法“SELECT MAX(DISTINCT expression) FROM 數據表名;”。
本教程操作環境:windows7系統、mysql8版本、Dell G3電腦。
在mysql中,可以利用“SELECT”語句和MAX()函數來查詢最大值。
MySQL MAX()
函數返回一組值中的最大值。MAX()
函數在許多查詢中非常方便,例如查找最大數量,最昂貴的產品以及客戶的最大付款。
MAX()
函數的語法如下:
MAX(DISTINCT expression);
如果添加DISTINCT
運算符,則MAX
函數返回不同值的最大值,它與所有值的最大值相同。 這意味著DISTINCT
運算符不會對MAX
函數產生任何影響(用不用DISTINCT
運算符都可以)。
請注意,DISTINCT
運算符在其他聚合函數(如COUNT,SUM和AVG)中生效。
我們來看看示例數據庫(yiibaidb)中的payments
表,其表結構如下所示 -
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
要在payments
表中獲得最大的付款,您可以使用以下查詢:
SELECT MAX(amount) FROM payments;
執行上面查詢語句,得到以下結果 -
mysql> SELECT MAX(amount) FROM payments; +-------------+ | MAX(amount) | +-------------+ | 120166.58 | +-------------+ 1 row in set
不僅要獲得最大的付款金額,還要獲得其他付款信息,如客戶編號,支票號碼和付款日期,您可以在子查詢中使用MAX
函數,如下所示:
SELECT * FROM payments WHERE amount = ( SELECT MAX(amount) FROM payments);
執行上面查詢語句,得到以下結果 -
+----------------+-------------+-------------+-----------+ | customerNumber | checkNumber | paymentDate | amount | +----------------+-------------+-------------+-----------+ | 141 | JE105477 | 2015-03-18 | 120166.58 | +----------------+-------------+-------------+-----------+ 1 row in set
上面查詢語句是怎么運行的?
子查詢返回所有的最大付款金額。
外部查詢獲取的金額等于從子查詢返回的最大金額的其他相關付款信息。
不使用MAX
函數的另一種方法是使用ORDER BY
子句以降序對結果集進行排序,并使用LIMIT
子句獲取第一行,如下查詢:
SELECT * FROM payments ORDER BY amount DESC LIMIT 1;
執行上面查詢語句,得到以下結果 -
+----------------+-------------+-------------+-----------+ | customerNumber | checkNumber | paymentDate | amount | +----------------+-------------+-------------+-----------+ | 141 | JE105477 | 2015-03-18 | 120166.58 | +----------------+-------------+-------------+-----------+ 1 row in set
如果您沒有在amount
列上創建索引,則第二個查詢執行速度更快,因為它會檢查payments
表中的所有行,而第一個查詢會檢查payments
表中的所有行兩次,一次是在子查詢中,另一次在外部查詢中。 但是,如果amount
列被索引,則第一個查詢將執行得更快。
要找到每個組的最大值,您可以在SELECT
語句中使用MAX
函數與GROUP BY
子句。
對于每個客戶,查詢獲得客戶已支付的最大付款,可使用以下查詢:
SELECT customerNumber, MAX(amount) FROM payments GROUP BY customerNumber ORDER BY MAX(amount);
執行上面查詢語句,得到以下查詢結果 -
+----------------+-------------+ | 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
您可以在HAVING
子句中使用GROUP BY
子句中的MAX
函數,以根據指定的條件為分組添加過濾器。
例如,以下查詢查找每個客戶的最大付款; 并根據返回款項,如下面查詢語句,只查詢金額超過80000
的付款 -
SELECT customerNumber, MAX(amount) FROM payments GROUP BY customerNumber HAVING MAX(amount) > 80000;
執行上面查詢語句,得到以下結果 -
+----------------+-------------+ | 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
“mysql如何查詢最大值”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。