Oracle クエリテーブルと関連テーブルを使用する方法

PHPz
リリース: 2023-04-17 09:54:18
オリジナル
1725 人が閲覧しました

データベース内のデータ量が増加するにつれて、テーブル間の関係はますます複雑になります。いくつかの関連テーブルのデータをクエリする必要がある場合、Oracle の関連クエリを使用するのは非常に効果的な方法です。この記事では、Oracle クエリ テーブルをリレーショナル テーブルとともに使用する方法について説明します。

Oracle で一般的に使用される相関クエリ方法には、内部結合、左結合、右結合、完全外部結合などがあります。

まず、内部接続の使用方法を紹介します。内部結合は、両方のテーブルで一致するデータを持つ行のみが返されることを意味します。たとえば、customer テーブル (customer) と order テーブル (order) の交差データ、つまり customer テーブル内の注文の顧客情報を検索する場合は、次の SQL ステートメントを使用してクエリを実行できます。

SELECT a.customer_id, a.customer_name, b.order_id, b.order_date
FROM customer a
INNER JOIN order b
ON a.customer_id = b.customer_id;
ログイン後にコピー

上記の SQL ステートメントでは、customer テーブルと order テーブルは INNER JOIN キーワードによって関連付けられており、関連付け条件は 2 つのテーブルの customer_id フィールドが等しいことです。 SELECT 句のフィールドは、顧客テーブルの顧客番号と顧客名、注文テーブルの注文番号と注文日です。

次に、左結合の使用方法を紹介します。左結合は、左側のテーブルのすべての行と、左側のテーブルに一致する右側のテーブルの行を返します。右側のテーブルに一致するデータがない場合は、NULL 値が返されます。たとえば、注文がない場合でも、すべての顧客情報とその注文情報を検索したい場合は、次の SQL ステートメントを使用してクエリを実行できます。

SELECT a.customer_id, a.customer_name, b.order_id, b.order_date
FROM customer a
LEFT JOIN order b
ON a.customer_id = b.customer_id;
ログイン後にコピー

上記の SQL ステートメントでは、customer テーブルと順序テーブルは LEFT JOIN キーワードの関連付けを渡します。 SELECT 句のフィールドは、顧客テーブルの顧客番号と顧客名、注文テーブルの注文番号と注文日でもあります。ここで、LEFT JOIN キーワードは左側のテーブルのすべての行を返すことを決定しているため、customer テーブルに注文に対応しない顧客情報がある場合、対応する注文番号と注文日が NULL 値として返されることに注意してください。

次に、右結合の使用方法を紹介します。右結合では、右側のテーブルのすべての行と、右側のテーブルに一致する左側のテーブルの行が返されます。左側のテーブルに一致するデータがない場合は、NULL 値が返されます。たとえば、すべての注文情報とその顧客情報を検索したい場合、customer テーブルにこれらの注文に対応する顧客情報がない場合でも、次の SQL ステートメントを使用してクエリを実行できます。上記の SQL ステートメントは、customer テーブルと RIGHT JOIN キーワードを介して order テーブルに関連付けられます。 SELECT 句のフィールドは、顧客テーブルの顧客番号と顧客名、注文テーブルの注文番号と注文日でもあります。ここで、RIGHT JOIN キーワードは右側のテーブルのすべての行を返すことを決定しているため、注文テーブル内の顧客に対応しない注文情報がある場合、対応する顧客番号と顧客名が NULL 値として返されることに注意してください。

最後に、完全外部結合の使用方法を紹介します。完全外部結合は、左のテーブルと右のテーブル間の左結合と右結合を指し、すべての行を返します。左側のテーブルに一致するデータがない場合は NULL 値が返され、右側のテーブルにも一致するデータがない場合は NULL 値が返されます。たとえば、customer テーブルと order テーブルに一致するデータがあるかどうかに関係なく、すべての顧客情報とその注文情報を検索したい場合は、次の SQL ステートメントを使用してクエリを実行できます。上記の SQL ステートメント、customer テーブルとオーダー テーブルは、FULL OUTER JOIN キーワードによって関連付けられています。 SELECT 句のフィールドは、顧客テーブルの顧客番号と顧客名、注文テーブルの注文番号と注文日でもあります。ここで、FULL OUTER JOIN キーワードは左右のテーブルのすべての行を返すことを決定しているため、customer テーブルまたは order テーブルに対応するデータがない場合、対応するフィールドは NULL 値を返すことに注意してください。

この記事の導入を通じて、Oracle クエリ テーブルでテーブルを関連付ける方法を習得したと思います。実際のアプリケーションでは、ニーズに応じて適切な相関クエリ方法を選択すると、クエリの効率が向上し、不要なクエリ結果を減らすことができます。

以上がOracle クエリテーブルと関連テーブルを使用する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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