在列中查找重复条目

时间:2010-12-23 21:00:21

标签: sql oracle subquery

我正在编写此查询以查找table1中的重复CTN记录。所以我的想法是,如果CTN_NO出现两次或更多次,我希望它在我的SELECT *语句输出中显示在顶部。

我尝试了以下子查询逻辑,但我需要拉

  SELECT *
         table1 
   WHERE S_IND='Y'
     and CTN_NO = (select CTN_NO 
                     from table1 
                    where S_IND='Y' 
                      and count(CTN_NO) < 2);
order by 2

2 个答案:

答案 0 :(得分:94)

使用:

  SELECT t.ctn_no
    FROM YOUR_TABLE t
GROUP BY t.ctn_no
  HAVING COUNT(t.ctn_no) > 1

...会显示表格中有重复项的ctn_no值。向WHERE添加标准将允许您进一步调整有重复的内容:

  SELECT t.ctn_no
    FROM YOUR_TABLE t
   WHERE t.s_ind = 'Y'
GROUP BY t.ctn_no
  HAVING COUNT(t.ctn_no) > 1

如果您想查看与副本相关联的其他列值,您将需要使用自联接:

SELECT x.*
  FROM YOUR_TABLE x
  JOIN (SELECT t.ctn_no
          FROM YOUR_TABLE t
      GROUP BY t.ctn_no
        HAVING COUNT(t.ctn_no) > 1) y ON y.ctn_no = x.ctn_no

答案 1 :(得分:2)

尝试此查询..它使用分析函数SUM:

SELECT * FROM
(  
 SELECT SUM(1) OVER(PARTITION BY ctn_no) cnt, A.*
 FROM table1 a 
 WHERE s_ind ='Y'   
)
WHERE cnt > 2

如果ctn_no重复次数超过2次,我不确定为什么要将记录识别为副本。对我来说,它不止一次重复它重复。在这种情况下,将查询的las部分更改为WHERE cnt > 1