Oracle 查询:如何将返回的记录限制为计数 > 1 但显示完整结果的记录?
Posted
技术标签:
【中文标题】Oracle 查询:如何将返回的记录限制为计数 > 1 但显示完整结果的记录?【英文标题】:Oracle query: how do I limit the returned records to only those having a count > 1 but show full results? 【发布时间】:2019-10-25 00:26:00 【问题描述】:我需要显示拥有多个 ID 的所有用户,但不返回拥有多个 ID 的用户。我尝试使用 group ,但我需要列出 ID 而不仅仅是计算它们,所以无法让它为我工作。我最终使用了下面的代码,但它返回了所有记录。
选择 id,fname,lname,ssn,dob 按 fname、lname、ssn、dob 划分的 count(id) 为 cnt 从表 按cnt desc排序;
【问题讨论】:
【参考方案1】:使用子查询:
select id, fname, lname, ssn, dob
from (select id, fname, lname, ssn, dob,
count(id) over (partition by fname, lname, ssn, dob) as cnt
from TABLE
) t
where cnt >= 2
order by cnt;
【讨论】:
【参考方案2】:WITH CTE (FNAME, LNAME, TALLY) AS
(
SELECT FNAME, LNAME, COUNT(ID) AS TALLY
FROM TABLE
HAVING COUNT(ID) > 1
)
SELECT T.ID, C.FNAME,C.LNAME FROM CTE C
JOIN TABLE T
ON C.FNAME = T.FNAME
AND C.LNAME = T.LNAME
【讨论】:
以上是关于Oracle 查询:如何将返回的记录限制为计数 > 1 但显示完整结果的记录?的主要内容,如果未能解决你的问题,请参考以下文章