Mysql-max-function

提供:Dev Guides
移動先:案内検索

MySQL-MAX関数

MySQL MAX 関数は、レコードセットの中で最大値を持つレコードを見つけるために使用されます。

*MAX* 関数を理解するために、次のレコードを持っている *employee_tbl* テーブルを考慮してください-
mysql> SELECT * FROM employee_tbl;
+------+------+------------+--------------------+
|  id  | name | work_date  | daily_typing_pages |
+------+------+------------+--------------------+
|   1  | John | 2007-01-24 |        250         |
|   2  | Ram  | 2007-05-27 |        220         |
|   3  | Jack | 2007-05-06 |        170         |
|   3  | Jack | 2007-04-06 |        100         |
|   4  | Jill | 2007-04-06 |        220         |
|   5  | Zara | 2007-06-06 |        300         |
|   5  | Zara | 2007-02-06 |        350         |
+------+------+------------+--------------------+
7 rows in set (0.00 sec)

さて、上記の表に基づいて、daily_typing_pagesの最大値を取得したい場合、次のコマンドを使用して簡単に取得できます-

mysql> SELECT MAX(daily_typing_pages)
   -> FROM employee_tbl;
+-------------------------+
| MAX(daily_typing_pages) |
+-------------------------+
|           350           |
+-------------------------+
1 row in set (0.00 sec)

次のように GROUP BY 句を使用して、各名前の最大値を持つすべてのレコードを見つけることができます-

mysql> SELECT id, name, MAX(daily_typing_pages)
   -> FROM employee_tbl GROUP BY name;
+------+------+-------------------------+
|  id  | name | MAX(daily_typing_pages) |
+------+------+-------------------------+
|   3  | Jack |           170           |
|   4  | Jill |           220           |
|   1  | John |           250           |
|   2  | Ram  |           220           |
|   5  | Zara |           350           |
+------+------+-------------------------+
5 rows in set (0.00 sec)
*MAX* 関数とともに *MIN* 関数を使用して、最小値を見つけることもできます。 次の例を試してください-
mysql> SELECT MIN(daily_typing_pages) least, MAX(daily_typing_pages) max
   -> FROM employee_tbl;
+-------+------+
| least |  max |
+-------+------+
|  100  |  350 |
+-------+------+
1 row in set (0.01 sec)