在 MySQL 中针对一个别名执行过滤操作?


为此,在 HAVING 子句中使用别名。

我们首先创建一个表 −

mysql> create table DemoTable755 (
   Id int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   Score1 int,
   Score2 int
);
Query OK, 0 rows affected (0.62 sec)

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

mysql> insert into DemoTable755(Score1,Score2) values(30,23);
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable755(Score1,Score2) values(50,60);
Query OK, 1 row affected (0.13 sec)
mysql> insert into DemoTable755(Score1,Score2) values(89,90);
Query OK, 1 row affected (0.29 sec)
mysql> insert into DemoTable755(Score1,Score2) values(99,99);
Query OK, 1 row affected (0.18 sec)
mysql> insert into DemoTable755(Score1,Score2) values(40,43);
Query OK, 1 row affected (0.14 sec)

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

mysql> select *from DemoTable755;

这将产生以下输出 -

+----+--------+--------+
| Id | Score1 | Score2 |
+----+--------+--------+
|  1 |     30 |     23 |
|  2 |     50 |     60 |
|  3 |     89 |     90 |
|  4 |     99 |     99 |
|  5 |     40 |     43 |
+----+--------+--------+
5 rows in set (0.00 sec)

以下是针对 MySQL 中的别名执行过滤操作的查询。在此,我们正在添加分数并在 HAVING 子句的查询中显示匹配结果。过滤记录显示 ID 以及带有分数的结果 −

mysql> select Score1+Score2 AS Result,DemoTable755.* from DemoTable755 having Result=83;

这将产生以下输出 -

+--------+----+--------+--------+
| Result | Id | Score1 | Score2 |
+--------+----+--------+--------+
|     83 |  5 |     40 |     43 |
+--------+----+--------+--------+
1 row in set (0.00 sec)

更新时间: 03-Sep-2019

293 次浏览

启动你的 职业

通过完成课程获得认证

开始
广告
© . All rights reserved.