メインコンテンツまでスキップ
メインコンテンツまでスキップ

INTERSECT句

INTERSECT句は、最初と二番目のクエリの両方からの結果の行のみを返します。クエリは、カラムの数、順序、型が一致している必要があります。INTERSECTの結果には重複行が含まれる場合があります。

複数のINTERSECTステートメントは、丸括弧が指定されていない場合、左から右に実行されます。INTERSECT演算子は、UNIONEXCEPT句よりも優先度が高いです。

条件は、あなたの要求に基づく任意の式である可能性があります。

1から10までの数字と3から8までの数字を交差させるシンプルな例を示します:

結果:

INTERSECTは、共通のカラム(またはカラム)を持つ2つのテーブルがある場合に便利です。結果が同じカラムを含む限り、2つのクエリの結果を交差させることができます。たとえば、取引価格とボリュームを含む数百万行の歴史的な暗号通貨データがあるとしましょう:

次に、私たちが所有している暗号通貨のリストとそれぞれのコインの数が含まれているholdingsという名前のテーブルがあるとしましょう:

INTERSECTを使って「$100以上で取引されたコインはどれですか?」という質問に答えることができます:

結果:

これは、何らかの時点でBitcoinとEthereumが100以上で取引されており、DOGEFIBitcoinDiamond100以上で取引されており、DOGEFIとBitcoin Diamondは100以上で取引されたことがない(少なくともこの例に示されているデータでは)ことを意味します。

INTERSECT DISTINCT

前のクエリでは、$100以上で取引されたBitcoinとEthereumの保有が複数ありました。重複行を削除する(すでに知っていることを繰り返すだけなので)ことができると良いでしょう。結果から重複行を排除するためにINTERSECTDISTINCTを追加できます:

結果:

関連情報