首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何避免所有存在复制的记录,而只获得唯一的记录?

如何避免所有存在复制的记录,而只获得唯一的记录?
EN

Stack Overflow用户
提问于 2018-06-25 05:01:59
回答 2查看 27关注 0票数 1

伙计们,

我有一个数据库表,如下所示:

代码语言:javascript
复制
uniqueId,asin,rank
1,abc,1
2,xyz,2
3,abc,1
4,xyz,2
5,opq,3

如您所见,asin's (abc和xyz)被重复。因此,我希望我的查询,以避免他们完全和返回我只(opq)。

诚挚的问候

乌萨马

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2018-06-25 05:04:39

我觉得你需要

代码语言:javascript
复制
select *
from yourtable a
where 1 = (
  select count(*)
  from yourtable
  where a.asin = asin
)

演示

票数 2
EN

Stack Overflow用户

发布于 2018-06-25 11:38:27

not exists应该具有最好的性能:

代码语言:javascript
复制
select t.*
from t
where not exists (select 1
                  from t t2
                  where t2.asin = t.asin and t2.id <> t.id
                 );

为了提高性能,您需要(asin, id)上的索引。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51016562

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档