SQL 列のエイリアス: 制限事項と解決策
SQL 列のエイリアスは、読みやすくするために結果列の名前を変更する便利な方法を提供します。 ただし、同じ SELECT
ステートメント内のさらなる計算でこれらのエイリアスを直接使用すると、多くの場合エラーが発生します。
問題: エイリアスの可用性
この問題は、SQL エンジンが SELECT
句を同時に処理するために発生します。 したがって、エイリアス名 (例: avg_time
、cnt
) は、ROUND(avg_time * cnt, 2)
.
解決策: エイリアス解決のためのサブクエリ
最も効果的な解決策は、元のクエリをサブクエリ内にネストすることです。これにより、エイリアスが適切に定義され、外側のクエリの SELECT
句でアクセスできる新しいスコープが作成されます。
例:
サブクエリを使用して問題を解決する方法は次のとおりです:
<code class="language-sql">SELECT stddev_time, max_time, avg_time, min_time, cnt, ROUND(avg_time * cnt, 2) AS slowdown FROM ( SELECT COALESCE(ROUND(stddev_samp(time), 2), 0) AS stddev_time, MAX(time) AS max_time, ROUND(AVG(time), 2) AS avg_time, MIN(time) AS min_time, COUNT(path) AS cnt, path FROM loadtime GROUP BY path ORDER BY avg_time DESC LIMIT 10 ) AS X;</code>
説明:
内部クエリはエイリアスを計算し、中間結果に割り当てます。外側のクエリは、これらの事前定義されたエイリアスを計算に利用して、元のエラーを回避します。 AS X
の使用はオプションですが、サブクエリに明確な名前を提供します。 このアプローチにより、正しいエイリアス解決が保証され、エイリアスが設定された列を含む複雑な計算が可能になります。
以上が後続の SELECT 式で列のエイリアスを使用できないのはなぜですか?また、それを修正するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。