Maison > Problème commun > Quelle est l'utilisation d'Oracle distinct

Quelle est l'utilisation d'Oracle distinct

zbt
Libérer: 2023-09-05 09:47:12
original
937 Les gens l'ont consulté

oracle的distinct用法是可以过滤结果集中的重复行,确保“SELECT”子句中返回指定的一列或多列的值是唯一的。其语法为“SELECT DISTINCT 列Quelle est lutilisation dOracle distinct,列Quelle est lutilisation dOracle distinct,列Quelle est lutilisation dOracle distinct... from 表名”,“distinct”会对返回的结果集进行排序,可以和“order by”结合使用,提高效率。

Quelle est l'utilisation d'Oracle distinct

SELECT DISTINCT可以用来过滤结果集中的重复行,确保SELECT子句中返回指定的一列或多列的值是唯一的。本文将为大家带来SELECT DISTINCT的具体用法。

Oracle SELECT DISTINCT用法

SELECT DISTINCT语句的语法如下:

SELECT DISTINCT

column_Quelle est lutilisation dOracle distinct
FROM
table_name;
Copier après la connexion

在上面语法中,table_name表的column_Quelle est lutilisation dOracle distinct列中的值将进行比较以过滤重复项。

要根据多列检索唯一数据,只需要在SELECT子句中指定列的列表,如下所示:

SELECT DISTINCT column_Quelle est lutilisation dOracle distinct,
 column_Quelle est lutilisation dOracle distinct,
...
FROM
table_name;
Copier après la connexion

在此语法中,column_Quelle est lutilisation dOracle distinct,column_Quelle est lutilisation dOracle distinct和column_n中的值的组合用于确定数据的唯一性。

DISTINCT子句只能在SELECT语句中使用。

请注意,在Oracle中DISTINCT和UNIQUE没有区别,二者为同义词,DISTINCT遵循ANSI标准,UNIQUE是Oracle特定的用法,从移植角度考虑,使用遵循ANSI标准的DISTINCT是一个更好的选择。

Oracle DISTINCT示例

下面来看看如何使用SELECT DISTINCT来看看它是如何工作的一些例子。

Quelle est lutilisation dOracle distinct. Oracle DISTINCT简单的例子

以下是一个table表

字段Quelle est lutilisation dOracle distinct 字段Quelle est lutilisation dOracle distinct
id name
Quelle est lutilisation dOracle distinct a
Quelle est lutilisation dOracle distinct b
Quelle est lutilisation dOracle distinct c
4 c
Quelle est lutilisation dOracle distinct b
Copier après la connexion

如果想用一条语句查询得到name不重复的所有数据,那就必须使用distinct去掉多余的重复记录。所以首先输入:

select *, count(distinct name) from table group by name
Copier après la connexion

然后我们再输入:

id name count(distinct name)
Copier après la connexion

得到结果:

Quelle est lutilisation dOracle distinct a Quelle est lutilisation dOracle distinct
Quelle est lutilisation dOracle distinct b Quelle est lutilisation dOracle distinct
Quelle est lutilisation dOracle distinct c Quelle est lutilisation dOracle distinct
Copier après la connexion

Quelle est lutilisation dOracle distinct. Oracle DISTINCT在一列上应用的例子

以下示例检索所有联系人的名字:

SELECT first_name
FROM contacts
ORDER BY first_name;
Copier après la connexion

执行上面查询语句,得到以下结果:

Quelle est lutilisation dOracle distinct

该查询返回了Quelle est lutilisation dOracle distinctQuelle est lutilisation dOracle distinct9行,表示联系人(contacts)表有Quelle est lutilisation dOracle distinctQuelle est lutilisation dOracle distinct9行。

要获得唯一的联系人名字,可以将DISTINCT关键字添加到上面的SELECT语句中,如下所示:

Quelle est lutilisation dOracle distinct

该查询返回了Quelle est lutilisation dOracle distinct0Quelle est lutilisation dOracle distinct行,表示联系人(contacts)表有Quelle est lutilisation dOracle distinct7行是重复的,它们已经被过滤了。

Quelle est lutilisation dOracle distinct. Oracle DISTINCT应用多列示例

看下面的order_items表,表的结构如下:

Quelle est lutilisation dOracle distinct

以下语句从order_items表中选择不同的产品ID和数量:

SELECT
DISTINCT product_id,
quantity
FROM
ORDER_ITEMS
ORDER BY product_id;
Copier après la connexion

执行上面查询语句,得到以下结果

Quelle est lutilisation dOracle distinct

在此示例中,product_id和quantity列的值都用于评估结果集中行的唯一性。

Quelle est lutilisation dOracle distinct. Oracle DISTINCT和NULL

DISTINCT将NULL值视为重复值。如果使用SELECT DISTINCT语句从具有多个NULL值的列中查询数据,则结果集只包含一个NULL值。

请参阅示例数据库中的locations表,结构如下所示:

Quelle est lutilisation dOracle distinctQuelle est lutilisation dOracle distinct

以下语句从state列中检索具有多个NULL值的数据:

SELECT DISTINCT state
FROM locations
ORDER BY state NULLS FIRST;
Copier après la connexion

执行上面示例代码,得到以下结果:

Quelle est lutilisation dOracle distinctQuelle est lutilisation dOracle distinct

正如上图所看到的,只返回一个NULL值。

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal