MySQL: WHERE 句の 'user_id' のあいまいさの解決
JOIN 操作を使用して複数のテーブルのデータをクエリする場合、次のことを確認することが重要です。列参照がどのテーブルに属するかについてはあいまいさがありません。この問題は、以下のコードに示すように、結合されたテーブルに同じ名前の列が存在する場合に発生します。
SELECT user.*, user_info.* FROM user INNER JOIN user_info ON user.user_id = user_info.user_id WHERE user_id=1
「where 句の user_id があいまいです」というエラー メッセージは、データベースがどのテーブルの user_id を判断できないことを示しています。列は WHERE 句で参照されます。このあいまいさを解決するには、列名とともに完全なテーブル名を指定する必要があります。
たとえば、ユーザー テーブルの user_id 列に基づいて結果をフィルターするには、コードを次のように変更する必要があります。 :
SELECT user.*, user_info.* FROM user INNER JOIN user_info ON user.user_id = user_info.user_id WHERE user.user_id=1
「user.user_id」を明示的に指定することで曖昧さがなくなり、データベースは WHERE 句が user テーブルの user_id 列を参照していることを認識できるようになります。この変更により、クエリは曖昧さのない意図した結果を返すようになります。
以上がMySQL WHERE 句の「user_id」の曖昧さを解決する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。