Why Aliased Aggregates Are Prohibited in HAVING Clauses
In SQL, users often encounter an error when attempting to use an alias for an aggregate in a HAVING clause. This stems from the specific order in which SQL processes queries.
The HAVING clause, which filters the results of a GROUP BY operation, is evaluated before the SELECT clause. As a result, aliases defined in the SELECT clause are not yet available when evaluating the HAVING clause.
To understand this better, let's consider the following logical sequence of query execution:
Since the HAVING clause is evaluated before the SELECT clause, it cannot reference aliases defined later in the query. This restriction explains why using an alias in a HAVING clause, as shown in the example, results in an "Invalid column name" error.
In contrast, aliases work in the ORDER BY clause because the ORDER BY clause is evaluated after the SELECT clause. Therefore, aliases defined in the SELECT clause are available for use in the ORDER BY clause.
The above is the detailed content of Why Can't I Use Aliased Aggregates in SQL's HAVING Clause?. For more information, please follow other related articles on the PHP Chinese website!