ホームページ > データベース > mysql チュートリアル > SELECT * クエリで ORA-00918: Ambiguous Column Definition エラーが発生するのはなぜですか?

SELECT * クエリで ORA-00918: Ambiguous Column Definition エラーが発生するのはなぜですか?

Linda Hamilton
リリース: 2025-01-13 21:50:49
オリジナル
303 人が閲覧しました

Why Does My SELECT * Query Result in an ORA-00918: Ambiguous Column Definition Error?

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>
ログイン後にコピー
サブクエリに ID という名前の列が複数あるため、

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 サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート