MSQL Spaltenalias?
baeckermna83
- datenbank
Hi!
Kann ich im Select Statement in der where clause keinen Spaltenalias benutzen?
Beispiel:
select CountryCode as Land, Percentage from CountryLanguage where Land ='CRI';
Das gibt einen Fehler, dass die Spalte Land nicht bekannt ist.
Hello,
Kann ich im Select Statement in der where clause keinen Spaltenalias benutzen?
hat mich eben zugegebenermaßen auch erstaunt, aber das Handbuch sagt dazu:
http://dev.mysql.com/doc/refman/5.1/en/problems-with-alias.html
You can use an alias to refer to a column in GROUP BY, ORDER BY, or HAVING clauses. Aliases can also be used to give columns better names:
SELECT SQRT(a*b) AS root FROM tbl_name GROUP BY root HAVING root > 0;
SELECT id, COUNT(*) AS cnt FROM tbl_name GROUP BY id HAVING cnt > 0;
SELECT id AS 'Customer identity' FROM tbl_name;
Standard SQL doesn't allow you to refer to a column alias in a WHERE clause. This restriction is imposed because when the WHERE code is executed, the column value may not yet be determined. For example, the following query is illegal:
SELECT id, COUNT(*) AS cnt FROM tbl_name WHERE cnt > 0 GROUP BY id;
The WHERE statement is executed to determine which rows should be included in the GROUP BY part, whereas HAVING is used to decide which rows from the result set should be used.
Liebe Grüße aus Syburg bei Dortmund
Tom vom Berg
echo $begrüßung;
Kann ich im Select Statement in der where clause keinen Spaltenalias benutzen?
Spaltenaliasnamen sind erst nach der Berechnung der Spalten verfügbar. Das WHERE sorgt nur dafür, dass die Ergebniszeilen der Tabellen eingeschränkt werden, ohne auf die tatsächlich davon zurückgelieferten Felder Rücksicht zu nehmen. Es kann nur Tabellenaliasnamen verwenden. Erst GROUP BY kann auf die Spalten Bezug nehmen.
echo "$verabschiedung $name";
echo $begrüßung;
»» Kann ich im Select Statement in der where clause keinen Spaltenalias benutzen?
Spaltenaliasnamen sind erst nach der Berechnung der Spalten verfügbar. Das WHERE sorgt nur dafür, dass die Ergebniszeilen der Tabellen eingeschränkt werden, ohne auf die tatsächlich davon zurückgelieferten Felder Rücksicht zu nehmen. Es kann nur Tabellenaliasnamen verwenden. Erst GROUP BY kann auf die Spalten Bezug nehmen.
echo "$verabschiedung $name";
Danke!