国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > MySQL > 正文

mysql如何查詢最大值

2024-07-24 12:33:57
字體:
來源:轉載
供稿:網友
  在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如何查詢最大值”的內容就介紹到這里了,感謝大家的閱讀。

(編輯:武林網)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 林周县| 绥中县| 民权县| 安平县| 合肥市| 清河县| 常德市| 永福县| 威信县| 吉首市| 永登县| 古田县| 通河县| 灵寿县| 宿州市| 定陶县| 溧水县| 大埔区| 宁远县| 阳高县| 奉节县| 广汉市| 绥江县| 晋江市| 宁明县| 易门县| 高碑店市| 盖州市| 襄城县| 美姑县| 洱源县| 吉木乃县| 北安市| 泉州市| 察哈| 潼关县| 栖霞市| 比如县| 都兰县| 泰来县| 西乌珠穆沁旗|