Oracle ORA-00918: あいまいな列定義エラーの解決
SELECT *
ステートメントを使用するときに ORA-00918 エラーが発生するとイライラします。このエラーは、同じ名前の列が結果セットに複数回出現し、どの列を取得するかを Oracle が判断できない場合に発生します。
次の SQL ステートメント:
<code class="language-sql">SELECT * FROM (SELECT DISTINCT(coaches.id), people.*, users.*, coaches.* FROM "COACHES" INNER JOIN people ON people.id = coaches.person_id INNER JOIN users ON coaches.person_id = users.person_id LEFT OUTER JOIN organizations_users ON organizations_users.user_id = users.id ) WHERE rownum <= 25</code>
SELECT *
句に問題があります:
COACHES.ID
PEOPLE.ID
USERS.ID
この曖昧さを解決するには、クエリで名前付き列を明示的に選択する必要があります。わかりやすくし、将来列を追加または名前変更する際の問題を回避するために、列のエイリアスを使用することをお勧めします。例:
<code class="language-sql">SELECT COALESCE(COACHES.ID, PEOPLE.ID, USERS.ID) AS ID, people.*, users.*, coaches.*, organizations_users.* FROM (SELECT DISTINCT(coaches.id), people.*, users.*, coaches.* FROM "COACHES" INNER JOIN people ON people.id = coaches.person_id INNER JOIN users ON coaches.person_id = users.person_id LEFT OUTER JOIN organizations_users ON organizations_users.user_id = users.id ) WHERE rownum <= 25</code>
この調整により、結果セットに ID 列のインスタンスが 1 つだけ存在するようになり、ORA-00918 エラーが解決され、データの整合性が確保されます。 COALESCE
この関数は、NULL 値が存在する可能性がある状況を処理し、最初の非 NULL ID 値を選択するために使用されます。 ただし、より良い解決策は、必要な列をすべて明示的に指定し、*
ワイルドカード文字の使用を避けることです。
以上がSELECT * クエリで ORA-00918: Ambiguous Column Definition エラーが発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。