如何在单个 MySQL 查询中查找最小值和最大值?


若要使用单个查询查找最小值和最大值,可使用 MySQL UNION。我们首先创建一个表 −

mysql> create table DemoTable
(
   Price int
);
Query OK, 0 rows affected (0.57 sec)

使用 insert 命令向表中插入一些记录 −

mysql> insert into DemoTable values(88);
Query OK, 1 row affected (0.30 sec)
mysql> insert into DemoTable values(100);
Query OK, 1 row affected (0.22 sec)
mysql> insert into DemoTable values(98);
Query OK, 1 row affected (0.15 sec)
mysql> insert into DemoTable values(120);
Query OK, 1 row affected (0.12 sec)

使用 select 语句显示表中的所有记录 −

mysql> select *from DemoTable;

这将生成以下输出 −

+-------+
| Price |
+-------+
| 88    |
| 100   |
| 98    |
| 120   |
+-------+
4 rows in set (0.00 sec)

以下是在一个 MySQL 查询中查找最小值和最大值的查询 −

mysql> select Price from DemoTable where Price=(select min(Price) from DemoTable)
   UNION
   select Price from DemoTable where Price=(select max(Price) from DemoTable);

这将生成以下输出 −

+-------+
| Price |
+-------+
| 88    |
| 120   |
+-------+
2 rows in set (0.00 sec)

更新于: 2019 年 9 月 27 日

342 次浏览

开启你的 职业

完成课程获得认证

开始
广告