Oracle の独自の使用法により、結果セット内の重複行をフィルタリングして、「SELECT」句で返される指定された列の値が一意であることを確認できます。構文は「SELECT DISTINCT カラム 1、カラム 2、カラム 3... テーブル名から」です。「distinct」は返された結果セットをソートし、「order by」と組み合わせて使用すると効率が向上します。
#この記事の動作環境: Windows 10 システム、Oracle バージョン 19c、DELL G3 コンピューター。
Oracle Distinct の使用法
SELECT DISTINCT を使用すると、結果セット内の重複行をフィルタリングして、SELECT 句で指定された 1 つ以上の列の値が確実に一致するようにすることができます。個性的。 。
これを使用して、非重複レコードのすべての値を返すのではなく、非重複レコードの数を返すためにのみ使用してください。その理由は、distinct は二重ループ クエリによってのみ解決できるためであり、これは間違いなく、非常に大量のデータを含む Web サイトの効率に直接影響します。
distinct は返された結果セットを並べ替えるため、効率を向上させるために order by と組み合わせて使用することをお勧めします。
Oracle SELECT DISTINCT の使用法
SELECT DISTINCT ステートメントの構文は次のとおりです。
SELECT DISTINCT column_1 FROM table_name;
上記の構文では、column_1 の値がtable_name テーブルの列は、重複をフィルターするために比較されます。
複数の列に基づいて一意のデータを取得するには、次のように SELECT 句で列のリストを指定するだけです:
SELECT DISTINCT column_1, column_2, ... FROM table_name;
この構文では、column_1、column_2、および column_n の値が組み合わせは、データの一意性を判断するために使用されます。
DISTINCT 句は、SELECT ステートメントでのみ使用できます。
Oracle では DISTINCT と UNIQUE に違いはないことに注意してください。これらは同義語です。DISTINCT は ANSI 標準に従い、UNIQUE は Oracle 固有です。移植の観点からは、次の DISTINCT を使用することをお勧めします。 ANSI 規格。
Oracle DISTINCT の例
SELECT DISTINCT の使用例をいくつか見て、その動作を確認しましょう。
1. Oracle DISTINCT の簡単な例
以下は表です
字段1 字段2 id name 1 a 2 b 3 c 4 c 5 b
1 つのステートメントを使用して、重複しない名前を持つすべてのデータをクエリする場合は、個別の重複レコードを使用する必要があります。冗長な重複レコードを削除します。最初に次のように入力します:
select *, count(distinct name) from table group by name
次に、次のように入力します:
id name count(distinct name)
そして結果を取得します:
1 a 1 2 b 1 3 c 1
2. 列
に適用される Oracle DISTINCT の例すべての連絡先の名前を取得する例:
SELECT first_name FROM contacts ORDER BY first_name;
上記のクエリ ステートメントを実行すると、次の結果が得られます:
クエリは 319 行を返しました。 、連絡先 (contacts) テーブルに 319 行があることを示します。
一意の連絡先名を取得するには、以下に示すように、上記の SELECT ステートメントに DISTINCT キーワードを追加できます。
クエリで返された行 302 は、次のことを意味します。連絡先テーブルの 17 行は重複しており、フィルターされています。
2. Oracle DISTINCT アプリケーションの複数列の例
下の order_items テーブルを見てください。テーブルの構造は次のとおりです:
次のステートメントは order_items からのものです。テーブル内の異なる製品 ID と数量を選択してください:
SELECT DISTINCT product_id, quantity FROM ORDER_ITEMS ORDER BY product_id;
上記のクエリ ステートメントを実行すると、次の結果が得られます
この例では、product_id 列と数量列の値を使用して、結果セット内の行の一意性を評価します。
3. Oracle DISTINCT と NULL
DISTINCT は、NULL 値を重複値として扱います。 SELECT DISTINCT ステートメントを使用して、複数の NULL 値を持つ列のデータをクエリする場合、結果セットには NULL 値が 1 つだけ含まれます。
サンプル データベースの location テーブルを参照してください。構造は次のとおりです。
次のステートメントは、状態から複数の NULL 値を含むデータを取得します。列:
SELECT DISTINCT state FROM locations ORDER BY state NULLS FIRST;
上記のコード例を実行すると、次の結果が得られます:
上の図からわかるように、NULL 値のみが返されます。 。
以上がOracleでのdistinctの使用法は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。