ホームページ >データベース >Oracle >Oracleでconnect byを使用する方法

Oracleでconnect byを使用する方法

下次还敢
下次还敢オリジナル
2024-04-30 08:51:17896ブラウズ

CONNECT BY は、Oracle で階層クエリを実行するために使用されます。具体的な手順としては、階層構造を作成し、接続条件を設定するために接続された列を指定します。以前のキーワードと現在のレベルの関係を指定します。共通の条件は、以前の列名 = 現在の列名です。より複雑な階層クエリを実行するには、START WITH、CONNECT_BY_ROOT、LEVEL などの高度な関数を使用します。

Oracleでconnect byを使用する方法

OracleでのCONNECT BYの使用法

簡単な説明

CONNECT BYは、階層構造を指定してデータを走査できる階層クエリを実行するためにOracleで使用されるキーワードです。これは、ツリー状のデータや階層関係のあるデータをクエリする場合に便利です。

構文

<code>SELECT columns
FROM table_name
CONNECT BY prior column_name = current column_name</code>

ここで:

  • columns: 選択される列
  • table_name: クエリされるテーブル名
  • prior column_name: 前のレベルの列名
  • current column_name : 現在のレベルの列名

使用方法

1. 階層を作成します

まず、階層を定義する列である接続の列を指定する必要があります。これは、親子関係を表すテーブル内の外部キー列にすることができます。

2. 接続条件を指定する

CONNECT BY 句は、previous キーワードと current キーワードを使用して接続条件を指定します。 prerior キーワードは前のレベルの列を参照し、current キーワードは現在のレベルの列を参照します。通常、結合条件は次のとおりです:

<code>prior column_name = current column_name</code>

これは、現在の行の前のレベルの列値が現在の行の列値と等しいことを意味します。

次の列を含む Employee というテーブルがあるとします。

  • Employee_ID
  • Manager_ID

Manager_ID 列は従業員のマネージャーを表し、階層の作成に使用できます。

すべての従業員とそのマネージャーを取得するには、次のクエリを使用できます:

<code>SELECT Employee_ID, Manager_ID, Employee_Name
FROM Employee
CONNECT BY prior Manager_ID = current Employee_ID;</code>

高度な機能

基本的な使用法に加えて、CONNECT BY にはいくつかの高度な機能もあります:

  • START WITH: を指定します。レベルトラバースの開始点。
  • CONNECT_BY_ROOT: 階層のルートノードを参照します。
  • LEVEL: 階層内の現在の行のレベルを取得します。

これらの関数を使用すると、特定のノードのすべての子ノードの検索やノード間の距離の計算など、より複雑な階層クエリを実行できます。

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

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。