ホームページ >データベース >mysql チュートリアル >SQL クエリで「Where 句の不明な列」エラーがスローされるのはなぜですか?
「Where 句の不明な列」SQL エラーのトラブルシューティング
SQL における恐ろしい「Where 句の不明な列」エラーは、クエリの評価順序の単純な誤解から発生することがよくあります。 SQL はクエリを右から左に処理します。つまり、WHERE
句は、 句で定義されたエイリアスが認識される前SELECT
に評価されます。
例で説明してみましょう:
<code class="language-sql">SELECT u_name AS user_name FROM users WHERE user_name = "john";</code>
このクエリは、エイリアス user_name
を使用して結果をフィルタリングしようとしますが、データベースは 句を評価した後WHERE
このエイリアスに遭遇します。 user_name
は users
テーブルの列ではないため、エラーが発生します。
解決策: 列参照を優先する
これを修正するには 2 つの簡単な方法があります:
WHERE
句の別名をテーブルの実際の列名に置き換えることです:<code class="language-sql">SELECT u_name AS user_name FROM users WHERE u_name = "john";</code>
これにより、データベースはフィルタリングに正しく識別された列を使用するようになります。
SELECT
節の式を括弧で囲んで、WHERE
節の評価前にエイリアス解決を強制することもできます:<code class="language-sql">SELECT (u_name) AS user_name FROM users WHERE user_name = "john";</code>
この方法は機能しますが、元の列名を使用するよりも可読性が低く、一般にあまり推奨されません。
評価順序を理解し、これらの解決策のいずれかを採用することで、「Where 句の不明な列」エラーを効果的に防止し、解決できます。
以上がSQL クエリで「Where 句の不明な列」エラーがスローされるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。