为此,在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)