Resolving "Multipart identifier cannot be bound" error
The SQL query error "Multipart identifier 'a.maxa' cannot be bound" indicates a conflict when mixing implicit and explicit joins. The following is a detailed explanation:
Mix implicit and explicit joins
In the provided query, both implicit joins (comma separated tables) and explicit joins (JOIN keyword) are used. While this is allowed, it needs to be handled carefully to avoid binding issues.
Understanding connection priorities
Explicit connections take precedence over implicit connections. This means that joins specified using the JOIN keyword will be performed before implicit joins.
Invalid alias reference
In your query, you are trying to perform an implicit join between the results of an explicit join between tables a and b and another table dkcd. However, due to the precedence of explicit joins, table a is not available when trying to reference a.maxa using dkcd's ON clause. This is where the error message comes from.
Rewrite query
To resolve this issue, you need to rewrite the query using consistent join syntax. One possible solution is to just use explicit joins:
<code class="language-sql">SELECT DISTINCT a.maxa, b.mahuyen, a.tenxa, b.tenhuyen, ISNULL(dkcd.tong, 0) AS tongdkcd FROM phuongxa AS a INNER JOIN quanhuyen AS b ON LEFT(a.maxa, 2) = b.mahuyen LEFT OUTER JOIN ( SELECT maxa, COUNT(*) AS tong FROM khaosat WHERE CONVERT(datetime, ngaylap, 103) BETWEEN '2011年9月1日' and '2011年9月5日' GROUP BY maxa ) AS dkcd ON dkcd.maxa = a.maxa WHERE a.maxa '99' ORDER BY a.maxa;</code>
In this query, all joins are explicit and table names are qualified using aliases in all cases. This ensures that the reference to a.maxa in the ON clause of dkcd is valid.
Explanation on the ORDER BY clause
As suggested by @Aaron Bertrand, it is recommended to qualify maxa with a specific alias a in the ORDER BY clause:
<code class="language-sql">ORDER BY a.maxa;</code>
This ensures that the sort is performed on the correct column. The date format has also been adjusted to make it easier to understand.
The above is the detailed content of Why Does My SQL Query Produce a 'Multi-Part Identifier Could Not Be Bound' Error?. For more information, please follow other related articles on the PHP Chinese website!