在MySQL中对别名执行过滤?

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

让我们首先创建一个表-

mysql> create table DemoTable755 (
   Id int NOT NULL AUTO_INCREMENT PRIMARY KEY,
   Score1 int,
   Score2 int
);

使用插入命令在表中插入一些记录-

mysql> insert into DemoTable755(Score1,Score2) values(30,23);
mysql> insert into DemoTable755(Score1,Score2) values(50,60);
mysql> insert into DemoTable755(Score1,Score2) values(89,90);
mysql> insert into DemoTable755(Score1,Score2) values(99,99);
mysql> insert into DemoTable755(Score1,Score2) values(40,43);

使用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)