oracle的distinct用法是可以过滤结果集中的重复行,确保“SELECT”子句中返回指定的一列或多列的值是唯一的。其语法为“SELECT DISTINCT 列1,列2,列3... from 表名”,“distinct”会对返回的结果集进行排序,可以和“order by”结合使用,提高效率。
本文的操作环境:Windows10系统、Oracle 19c版本、DELL G3电脑。
Oracle Distinct用法
SELECT DISTINCT可以用来过滤结果集中的重复行,确保SELECT子句中返回指定的一列或多列的值是唯一的。
只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是distinct只有用二重循环查询来解决,而这样对于一个数据量非常大的站来说,无疑是会直接影响到效率的。
distinct 会对返回的结果集进行排序,所以,最好和order by 结合使用,可以提高效率。
Oracle SELECT DISTINCT用法
SELECT DISTINCT语句的语法如下:
SELECT DISTINCT column_1 FROM table_name;
在上面语法中,table_name表的column_1列中的值将进行比较以过滤重复项。
要根据多列检索唯一数据,只需要在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特定的用法,从移植角度考虑,使用遵循ANSI标准的DISTINCT是一个更好的选择。
Oracle DISTINCT示例
下面来看看如何使用SELECT DISTINCT来看看它是如何工作的一些例子。
1. Oracle DISTINCT简单的例子
以下是一个table表
字段1 字段2 id name 1 a 2 b 3 c 4 c 5 b
如果想用一条语句查询得到name不重复的所有数据,那就必须使用distinct去掉多余的重复记录。所以首先输入:
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行。
要获得唯一的联系人名字,可以将DISTINCT关键字添加到上面的SELECT语句中,如下所示:
该查询返回了302行,表示联系人(contacts)表有17行是重复的,它们已经被过滤了。
2. Oracle DISTINCT应用多列示例
看下面的order_items表,表的结构如下:
以下语句从order_items表中选择不同的产品ID和数量:
SELECT DISTINCT product_id, quantity FROM ORDER_ITEMS ORDER BY product_id;
执行上面查询语句,得到以下结果
在此示例中,product_id和quantity列的值都用于评估结果集中行的唯一性。
3. Oracle DISTINCT和NULL
DISTINCT将NULL值视为重复值。如果使用SELECT DISTINCT语句从具有多个NULL值的列中查询数据,则结果集只包含一个NULL值。
请参阅示例数据库中的locations表,结构如下所示:
以下语句从state列中检索具有多个NULL值的数据:
SELECT DISTINCT state FROM locations ORDER BY state NULLS FIRST;
执行上面示例代码,得到以下结果:
正如上图所看到的,只返回一个NULL值。
以上是oracle的distinct用法是什么的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

SublimeText3汉化版
中文版,非常好用

Atom编辑器mac版下载
最流行的的开源编辑器

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

禅工作室 13.0.1
功能强大的PHP集成开发环境

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中