溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

mysql如何查詢最大值

發布時間:2021-12-31 15:35:54 來源:億速云 閱讀:3064 作者:iii 欄目:MySQL數據庫

本篇內容介紹了“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)中生效。

MySQL MAX函數示例

我們來看看示例數據庫(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

MySQL MAX函數在子查詢中

不僅要獲得最大的付款金額,還要獲得其他付款信息,如客戶編號,支票號碼和付款日期,您可以在子查詢中使用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列被索引,則第一個查詢將執行得更快。

具有GROUP BY子句的MySQL MAX

要找到每個組的最大值,您可以在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子句的MySQL MAX

您可以在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如何查詢最大值”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女