MySQL 查詢以選擇最大和最小工資行?


為此,請使用子查詢以及 MIN() 和 MAX()。要顯示最大值和最小值,請使用 UNION ALL。讓我們先建立一個表 -

mysql> create table DemoTable
   -> (
   -> EmployeeName varchar(20),
   -> EmployeeSalary int
   -> );
Query OK, 0 rows affected (0.70 sec)

使用 insert 命令在表中插入一些記錄 -

mysql> insert into DemoTable values('Bob',8800);
Query OK, 1 row affected (0.12 sec)
mysql> insert into DemoTable values('Chris',9800);
Query OK, 1 row affected (0.63 sec)
mysql> insert into DemoTable values('David',7600);
Query OK, 1 row affected (0.11 sec)
mysql> insert into DemoTable values('Sam',9600);
Query OK, 1 row affected (0.14 sec)

使用 select 語句顯示錶中的所有記錄 -

mysql> select *from DemoTable;

這將產生以下輸出 -

+--------------+----------------+
| EmployeeName | EmployeeSalary |
+--------------+----------------+
|          Bob |           8800 |
|        Chris |           9800 |
|        David |           7600 |
|          Sam |           9600 |
+--------------+----------------+
4 rows in set (0.00 sec)

以下是要選擇最小工資行的查詢 -

mysql> select *from DemoTable
   -> where EmployeeSalary in ( select max(EmployeeSalary) from DemoTable
   -> union all
   -> select min(EmployeeSalary) from DemoTable
   -> );

這將產生以下輸出 -

+--------------+----------------+
| EmployeeName | EmployeeSalary |
+--------------+----------------+
|        Chris |           9800 |
|        David |           7600 |
+--------------+----------------+
2 rows in set (0.05 sec)

更新於: 12-Dec-2019

776 瀏覽

職業生涯起步

完成課程以獲得認證

開始
廣告