distinct oracle用法 - CSDN
精华内容
参与话题
  • Oracledistinct用法实例 摘要: 此外,distinct 会对返回的结果集进行排序 所以会大大影响查询效率,大数据集时比较明显 。所以,最好和order by 结合使用,可以提高效率 。 select distinct a,b,c ...

    Oracle中distinct的用法实例

    摘要:

    此外,distinct 会对返回的结果集进行排序 所以会大大影响查询效率,大数据集时比较明显 所以,最好和order by 结合使用,可以提高效率 

    select  distinct  a,b,c from t;表t里列的顺序为c,a,b ,则distinct 排序时是按前者还是后者来呢?


            distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用 它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是distinct只有用二重循环查询来解决,而这样对于一个数据量非常大的站来说,无疑是会直接影响到效率的。

    下面先来看看例子:

    table表

    字段1     字段2 
       id        name 
       1           a 
       2           b 
       3           c 
       4           c 
       5           b

    表结构大概这样,这只是一个简单的例子,实际情况会复杂得多。

    比如我想用一条语句查询得到name不重复的所有数据,那就必须使用distinct去掉多余的重复记录。

    select distinct name from table 
    得到的结果是:

    ———- 

    name 
       a 
       b 
       c

    好像达到效果了,可是,我想要得到的是id值呢?改一下查询语句吧:

    select distinct name, id from table

    结果会是:

    ———- 

    id name 
       1 a 
       2 b 
       3 c 
       4 c 
       5 b

    distinct怎么没起作用?作用是起了的,不过他同时作用了两个字段,也就是必须得id与name都相同的才会被排除。。。。。。。

    我们再改改查询语句:

    select id, distinct name from table

    很遗憾,除了错误信息你什么也得不到,distinct必须放在开头。难到不能把distinct放到where条件里?能,但是照样会报错。

    ————————————————————————————————————

    下面方法可行:

    select *, count(distinct name) from table group by name

    结果:

       id name count(distinct name) 
       1 a 1 
       2 b 1 
       3 c 1

    最后一项是多余的,不用管就行了,目的达到。。。。。

    group by 必须放在 order by 和 limit之前,不然会报错

    ===========================================================

    另一篇网上转载的博文:

    Oracle distince 用法和删除重复数据

    oracle distinct语句的用法 创建视图时过滤数据 
    distinct的只显示一次重复出更的值。 
    不过这个值出现多少次只显示一次。 
    select distinct 字段名1,字段名2 from 表格 order by 字段名1 
    distinct 字段名1 意思是只显示一次字段名1显示的是第一次出现的。 
    最好和order by 结合使用。可以提高效率 
    distinct 返回唯一的结果集 
    注意,是结果集,如果你选了N个字段,当N个字段都相同时 
    才会被视为相同,而只返加一个 
    当然,如果N=1的话,情况就会比较明显 
    此外,distinct 会对返回的结果集进行排序 所以会大大影响查询效率,大数据集时比较明显 
    select distinct hjrq from T_MIDDLE_HJCG order by hjrq 
    asc 增序 默认 
    desc 降序

    Oracle 中如何删除重复数据

    我们可能会出现这种情况,某个表原来设计不周全,导致表里面的数据数据重复,那么,如何对重复的数据进行删除呢? 
    重复的数据可能有这样两种情况,第一种时表中只有某些字段一样,第二种是两行记录完全一样。

    一、对于部分字段重复数据的删除 
    先来谈谈如何查询重复的数据吧。 
    下面语句可以查询出那些数据是重复的: 
    select 字段1,字段2,count(*) from 表名 group by 字段1,字段2 having count(*) > 1 
    将上面的>号改为=号就可以查询出没有重复的数据了。 
    想要删除这些重复的数据,可以使用下面语句进行删除 
    delete from 表名 a where 字段1,字段2 in 
    (select 字段1,字段2,count(*) from 表名 group by 字段1,字段2 having count(*) > 1) 
    上面的语句非常简单,就是将查询到的数据删除掉。不过这种删除执行的效率非常低,对于大数据量来说,可能会将数据库吊死。所以我建议先将查询到的重复的数据插入到一个临时表中,然后对进行删除,这样,执行删除的时候就不用再进行一次查询了。如下: 
    CREATE TABLE 临时表 AS 
    (select 字段1,字段2,count(*) from 表名 group by 字段1,字段2 having count(*) > 1) 
    上面这句话就是建立了临时表,并将查询到的数据插入其中。 
    下面就可以进行这样的删除操作了: 
    delete from 表名 a where 字段1,字段2 in (select 字段1,字段2 from 临时表); 
    这种先建临时表再进行删除的操作要比直接用一条语句进行删除要高效得多。

    这个时候,大家可能会跳出来说,什么?你叫我们执行这种语句,那不是把所有重复的全都删除吗?而我们想保留重复数据中最新的一条记录啊!大家不要急,下面我就讲一下如何进行这种操作。 
    在oracle中,有个隐藏了自动rowid,里面给每条记录一个唯一的rowid,我们如果想保留最新的一条记录, 
    我们就可以利用这个字段,保留重复数据中rowid最大的一条记录就可以了。 
    下面是查询重复数据的一个例子: 
    select a.rowid,a.* from 表名 a 
    where a.rowid != 

    select max(b.rowid) from 表名 b 
    where a.字段1 = b.字段1 and 
    a.字段2 = b.字段2 

    下面我就来讲解一下,上面括号中的语句是查询出重复数据中rowid最大的一条记录。 
    而外面就是查询出除了rowid最大之外的其他重复的数据了。 
    由此,我们要删除重复数据,只保留最新的一条数据,就可以这样写了: 
    delete from 表名 a 
    where a.rowid != 

    select max(b.rowid) from 表名 b 
    where a.字段1 = b.字段1 and 
    a.字段2 = b.字段2 
    )

    随便说一下,上面语句的执行效率是很低的,可以考虑建立临时表,讲需要判断重复的字段、rowid插入临时表中,然后删除的时候在进行比较。 
    create table 临时表 as 
    select a.字段1,a.字段2,MAX(a.ROWID) dataid from 正式表 a GROUP BY a.字段1,a.字段2; 
    delete from 表名 a 
    where a.rowid != 

    select b.dataid from 临时表 b 
    where a.字段1 = b.字段1 and 
    a.字段2 = b.字段2 
    ); 
    commit;

    二、对于完全重复记录的删除

    对于表中两行记录完全一样的情况,可以用下面语句获取到去掉重复数据后的记录: 
    select distinct * from 表名 
    可以将查询的记录放到临时表中,然后再将原来的表记录删除,最后将临时表的数据导回原来的表中。如下: 
    CREATE TABLE 临时表 AS (select distinct * from 表名); 
    drop table 正式表; 
    insert into 正式表 (select * from 临时表); 
    drop table 临时表;

    如果想删除一个表的重复数据,可以先建一个临时表,将去掉重复数据后的数据导入到临时表,然后在从 
    临时表将数据导入正式表中
    ,如下: 
    INSERT INTO t_table_bak 
    select distinct * from t_table;

    展开全文
  • oracle distinct用法

    2010-12-14 14:32:44
    PostID=14525538[/url] ...oracle distinct语句的用法 创建视图时过滤数据  distinct的只显示一次重复出更的值。  不过这个值出现多少次只显示一次。  select distinct 字段名1,字段名2 fr...
    转自:[url]http://blog.tianya.cn/blogger/post_read.asp?BlogID=144699&PostID=14525538[/url]

    oracle distinct语句的用法 创建视图时过滤数据
      distinct的只显示一次重复出更的值。
      不过这个值出现多少次只显示一次。
      select distinct 字段名1,字段名2 from 表格 order by 字段名1
      distinct 字段名1 意思是只显示一次字段名1显示的是第一次出现的。
      最好和order by 结合使用。可以提高效率
      distinct 返回唯一的结果集
      注意,是结果集,如果你选了N个字段,当N个字段都相同时
      才会被视为相同,而只返加一个
      当然,如果N=1的话,情况就会比较明显
      此外,distinct 会对返回的结果集进行排序 所以会大大影响查询效率,大数据集时比较明显
      
      select distinct hjrq from T_MIDDLE_HJCG order by hjrq
      
      
      asc 增序 默认
      desc 降序
      
      Oracle 中如何删除重复数据
      
      
      
      我们可能会出现这种情况,某个表原来设计不周全,导致表里面的数据数据重复,那么,如何对重复的数据进行删除呢?
      重复的数据可能有这样两种情况,第一种时表中只有某些字段一样,第二种是两行记录完全一样。
      一、对于部分字段重复数据的删除
      先来谈谈如何查询重复的数据吧。
      下面语句可以查询出那些数据是重复的:
      select 字段1,字段2,count(*) from 表名 group by 字段1,字段2 having count(*) > 1
      将上面的>号改为=号就可以查询出没有重复的数据了。
      想要删除这些重复的数据,可以使用下面语句进行删除
      delete from 表名 a where 字段1,字段2 in
      (select 字段1,字段2,count(*) from 表名 group by 字段1,字段2 having count(*) > 1)
      上面的语句非常简单,就是将查询到的数据删除掉。不过这种删除执行的效率非常低,对于大数据量来说,可能会将数据库吊死。所以我建议先将查询到的重复的数据插入到一个临时表中,然后对进行删除,这样,执行删除的时候就不用再进行一次查询了。如下:
      CREATE TABLE 临时表 AS
      (select 字段1,字段2,count(*) from 表名 group by 字段1,字段2 having count(*) > 1)
      上面这句话就是建立了临时表,并将查询到的数据插入其中。
      下面就可以进行这样的删除操作了:
      delete from 表名 a where 字段1,字段2 in (select 字段1,字段2 from 临时表);
      这种先建临时表再进行删除的操作要比直接用一条语句进行删除要高效得多。
      
      这个时候,大家可能会跳出来说,什么?你叫我们执行这种语句,那不是把所有重复的全都删除吗?而我们想保留重复数据中最新的一条记录啊!大家不要急,下面我就讲一下如何进行这种操作。
      在oracle中,有个隐藏了自动rowid,里面给每条记录一个唯一的rowid,我们如果想保留最新的一条记录,
      我们就可以利用这个字段,保留重复数据中rowid最大的一条记录就可以了。
      下面是查询重复数据的一个例子:
      select a.rowid,a.* from 表名 a
      where a.rowid !=
      (
      select max(b.rowid) from 表名 b
      where a.字段1 = b.字段1 and
      a.字段2 = b.字段2
      )
      下面我就来讲解一下,上面括号中的语句是查询出重复数据中rowid最大的一条记录。
      而外面就是查询出除了rowid最大之外的其他重复的数据了。
      由此,我们要删除重复数据,只保留最新的一条数据,就可以这样写了:
      delete from 表名 a
      where a.rowid !=
      (
      select max(b.rowid) from 表名 b
      where a.字段1 = b.字段1 and
      a.字段2 = b.字段2
      )
      
      随便说一下,上面语句的执行效率是很低的,可以考虑建立临时表,讲需要判断重复的字段、rowid插入临时表中,然后删除的时候在进行比较。
      create table 临时表 as
      select a.字段1,a.字段2,MAX(a.ROWID) dataid from 正式表 a GROUP BY a.字段1,a.字段2;
      delete from 表名 a
      where a.rowid !=
      (
      select b.dataid from 临时表 b
      where a.字段1 = b.字段1 and
      a.字段2 = b.字段2
      );
      commit;
      
      二、对于完全重复记录的删除
      
      对于表中两行记录完全一样的情况,可以用下面语句获取到去掉重复数据后的记录:
      select distinct * from 表名
      可以将查询的记录放到临时表中,然后再将原来的表记录删除,最后将临时表的数据导回原来的表中。如下:
      CREATE TABLE 临时表 AS (select distinct * from 表名);
      drop table 正式表;
      insert into 正式表 (select * from 临时表);
      drop table 临时表;
      
      如果想删除一个表的重复数据,可以先建一个临时表,将去掉重复数据后的数据导入到临时表,然后在从
      临时表将数据导入正式表中,如下:
      INSERT INTO t_table_bak
      select distinct * from t_table;
      
    展开全文
  • oracledistinct用法详解

    千次阅读 2016-12-16 09:47:32
    distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是distinct只有用二重循环查询来解决,而这样对于一个数据量非常大的站来说,...

    作者:Eric.Yan

    distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是distinct只有用二重循环查询来解决,而这样对于一个数据量非常大的站来说,无疑是会直接影响到效率的。

    下面先来看看例子:

    table表

    字段1     字段2    id        name    1           a    2           b    3           c    4           c    5           b

    库结构大概这样,这只是一个简单的例子,实际情况会复杂得多。

    比如我想用一条语句查询得到name不重复的所有数据,那就必须使用distinct去掉多余的重复记录。

    select distinct name from table 得到的结果是:

    ----------

    name    a    b    c

    好像达到效果了,可是,我想要得到的是id值呢?改一下查询语句吧:

    select distinct name, id from table

    结果会是:

    ----------

    id name    1 a    2 b    3 c    4 c    5 b

    distinct怎么没起作用?作用是起了的,不过他同时作用了两个字段,也就是必须得id与name都相同的才会被排除。。。。。。。

    我们再改改查询语句:

     select id, distinct name from table

    很遗憾,除了错误信息你什么也得不到,distinct必须放在开头。难到不能把distinct放到where条件里?能,照样报错。

    ------------------------------------------------------------------------------------------------------------

    下面方法也不可行:

    select *, count(distinct name) from table group by name

    结果:

    ORA-00979: not a GROUP BY expression
    00979. 00000 - "not a GROUP BY expression"

    依然报错, 

    group by 必须放在 order by 和 limit之前,不然会报错

    ------------------------------------------------------------------------------------------------------------

    偶认为这样可行

    select max(id), name from table group by name;

    结果:

    id name
    1  a
    2  b
    4  c
    5  d

    用法二:

    一、数据:

    1    zjx    001    AAAiBZAAQAAAAVPAAA
    2    zjx    002    AAAiBZAAQAAAAVPAAB
    3    zjx    001    AAAiBZAAQAAAAVPAAC

    二、多字段

    select distinct t.name,t.code from test1 t
    select distinct t.* from test1 t

    结果:

    1    zjx    001
    2    zjx    002

    三、单字段

    select distinct t.name from test1 t

    结果:

    1    zjx

    展开全文
  • Oracle数据库中distinct用法

    千次阅读 2013-09-04 09:36:27
    distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用 它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是distinct只有用二重循环查询来解决,而这样对于一个数据量非常大的站来说...
    distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用 它来返回不重复记录的条数,而不是用它来返回不重记录的所有值。其原因是distinct只有用二重循环查询来解决,而这样对于一个数据量非常大的站来说,无疑是会直接影响到效率的。
    

    下面先来看看例子:

    table表

    字段1     字段2
       id        name
       1           a
       2           b
       3           c
       4           c
       5           b

    库结构大概这样,这只是一个简单的例子,实际情况会复杂得多。

    比如我想用一条语句查询得到name不重复的所有数据,那就必须使用distinct去掉多余的重复记录。

    select distinct name from table
    得到的结果是:

     

    ---------- 

    name
       a
       b
       c

    好像达到效果了,可是,我想要得到的是id值呢?改一下查询语句吧:

    select distinct name, id from table

    结果会是:

    ---------- 

    id name
       1 a
       2 b
       3 c
       4 c
       5 b

    distinct怎么没起作用?作用是起了的,不过他同时作用了两个字段,也就是必须得id与name都相同的才会被排除。。。。。。。

    我们再改改查询语句:

    select id, distinct name from table

    很遗憾,除了错误信息你什么也得不到,distinct必须放在开头。难到不能把distinct放到where条件里?能,照样报错。

    ------------------------------------------------------------------------------------------------------------

    下面方法可行:

    select *, count(distinct name) from table group by name

    结果:

       id name count(distinct name)
       1 a 1
       2 b 1
       3 c 1

    最后一项是多余的,不用管就行了,目的达到。。。。。

    group by 必须放在 order by 和 limit之前,不然会报错

    展开全文
  • oracledistinct和count函数组合使用

    万次阅读 2017-01-11 08:56:21
    oracle中的distinct关键字和count函数需要经常组合起来使用 例如,如果我们拿到一个仅有员工基本信息的列表,我们希望得到这个公司共有多少个部门。 我们可以这样做: select count(a.deptno) from ...
  • Oracle——distinct用法(效率)

    万次阅读 2015-12-31 16:28:09
    Oracle——distinct用法 博客分类:  Oracle oracledistinctgroup by  distinct这个关键字来过滤掉多余的重复记录只保留一条,但往往只用 它来返回不重复记录的条数,而不是用它来返回不...
  • oracle统计数量count和distinct组合使用

    千次阅读 2015-07-21 15:12:28
    先去除重复的,然后使用count计算数量 select count(distinct(t.列)) from 表 t
  • ORACLE中的distinct用法

    千次阅读 2012-11-29 11:29:18
    distinct主要是统计不重复的字段,过滤掉重复的字段,对重复的字段只后去一次  eg.  我现在要14和6 这个是人员的id   SELECT DISTINCT(t.user_id) from 表名 t  查询结果于下:  我还要...
  • oracle中SELECT DISTINCT 的非常规用法

    千次阅读 2017-02-09 17:03:53
    先说说distinct。 “在表中,可能会包含重复值。这并不成问题,不过,有时您也许希望仅仅列出不同(distinct)的值。关键词 DISTINCT 用于返回唯一不同的值。”-------来自w3cschool。 比如我遇到的问题:表内有...
  • oracle数据库——distinct函数详解

    千次阅读 2019-05-15 17:31:33
    1.问题:oracle中在使用distinct函数去重的时候,单列可以去重,多列去重后仍会有重复数据。 语法:SELECT DISTINCT 列名称 FROM 表名称 (1)单列 (2)多列 可以看出distinct函数去重是无法获得我们需要的...
  • oracledistinct用法

    千次阅读 2016-03-30 15:54:14
    select distinct name from A 2、作用于多列 select distinct name, id from A select distinct xing, ming from B 返回的结果为两行,这说明distinct并非是对xing和ming两列“字符串拼接”后再去重的,而是分别...
  • SELECT中的UNIQUE和DISTINCT有区别吗?

    千次阅读 2019-09-23 20:59:32
    Oracle数据库中,SELECT语句里的UNIQUE和DISTINCT是否存在区别?答案如下: 没有区别! 2 查阅资料 直奔官方文档,我查看了Oracle 12.2的《SQL Language Reference》,地址为...
  • Oracle listagg去重distinct三种方法总结

    万次阅读 2020-04-23 20:04:07
    最近在工作中,在写oracle统计查询的时候,遇到listagg聚合函数分组聚合之后出现很多重复数据的问题,于是研究了一下listagg去重的几种方法,以下通过实例讲解三种实现listagg去重的方法。 二、方法 首先还原...
  • oracle 数据库 去重查询

    万次阅读 2017-05-23 15:03:50
    数据库多字段去重 方法介绍:distinct 关键字、group by 、row_number() over()
  • Oracle三种去重的方法 distinct group by rowid 分组函数:作用于一组数据,并对一组数据返回一个值 常见的分组函数有: count 返回找到的记录数 min 返回一个数字列或计算列的最小值 max 返回一个数字列或计算列...
  • PLSQL如何让distinct 只作用于一个字段,重复相同的记录。求解~~~~(>_<)~~~~
  • 今天在编写存储的时候需要使用到wm_concat这个函数,进行编译的时候提示ORA-30482错误,存储过程大概是如下create or replace procedure pd_test ( out_test_query out sys_refcursor ) is begin open out_test_...
  • 使用下面语句进行查询 select distinct ID,BOOKID,GOODPRICE from HH_BOOK_GOOD order by GOODID; 报ORA-01791:不是SELECTed表达式 原因是order by后面的GOODID字段不在select查询结果字段之中,因为使用distinct...
  • Oracle去重函数(一)

    千次阅读 2019-06-12 17:43:23
    1、distinct (1)、常用的distinct select distinct column from table; (2)、统计去重后数量 select count(distinct column) from table;–查去重后数量 (3)、distinct必须放在开头 select id, distinct name ...
1 2 3 4 5 ... 20
收藏数 34,610
精华内容 13,844
热门标签
关键字:

distinct oracle用法