日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > 数据库 >内容正文

数据库

MySQL max()函数

發布時間:2023/12/3 数据库 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 MySQL max()函数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

轉載自??MySQL max()函數

MySQL 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) FROMpayments;

執行上面查詢語句,得到以下結果 -

mysql> SELECT MAX(amount) FROMpayments; +-------------+ | MAX(amount) | +-------------+ | 120166.58 | +-------------+ 1 row in set

?

MySQL MAX函數在子查詢中

不僅要獲得最大的付款金額,還要獲得其他付款信息,如客戶編號,支票號碼和付款日期,您可以在子查詢中使用MAX函數,如下所示:

SELECT * FROMpayments WHEREamount = (SELECT MAX(amount)FROMpayments);

執行上面查詢語句,得到以下結果 -

+----------------+-------------+-------------+-----------+ | customerNumber | checkNumber | paymentDate | amount | +----------------+-------------+-------------+-----------+ | 141 | JE105477 | 2015-03-18 | 120166.58 | +----------------+-------------+-------------+-----------+ 1 row in set

上面查詢語句是怎么運行的?

  • 子查詢返回所有的最大付款金額。
  • 外部查詢獲取的金額等于從子查詢返回的最大金額的其他相關付款信息。

不使用MAX函數的另一種方法是使用ORDER BY子句以降序對結果集進行排序,并使用LIMIT子句獲取第一行,如下查詢:

SELECT * FROMpayments 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) FROMpayments 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) FROMpayments 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?MAX函數來查找一組值中的最大值。

總結

以上是生活随笔為你收集整理的MySQL max()函数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。