根据字段筛选重复的行

时间:2013-06-20 18:53:00

标签: sql sql-server

我有几个记录(账单)基本上是彼此重复的,除了一个字段,它代表账单所在的语言。

例如:

ID,BillID,Account,Name,Amount,Lang
1,0001,abcd,John Smith,10.99,ENG
2,0002,qwer,Jane Doe,9.99,ENG
3,0001,abcd,John Smith,10.99,SPA
4,0003,abcd,John Smith,4.99,CHI

所有字段都是字符串,ID除外,它是一个自动编号。

在我的SQL选择中,我有

SELECT * 
FROM Bills 
WHERE Account='abcd'

并且它总共返回3行,但同一帐单有2行。我需要为特定帐户返回唯一的帐单。因此,在上面的场景中,我想检索2个账单,其中包含billID 0003和SPA或ENG版本的0001,但不是两者。

查询是什么?

谢谢

编辑:我不能依赖一直存在的特定语言。例如,我不能说SELECT * FROM Bills WHERE Account='abcd' AND Lang='ENG',因为有时一项法案可能只使用一种语言,而不是ENG,有时也可能是多种语言的任何组合。

4 个答案:

答案 0 :(得分:12)

可能最简单的方法是使用ROW_NUMBERPARTITION BY

SELECT * FROM (
   SELECT b.*,
   ROW_NUMBER() OVER (PARTITION BY BillID ORDER BY Lang) as num
   FROM Bills b
   WHERE Account = 'abcd'
) tbl
WHERE num = 1

答案 1 :(得分:7)

select
ID,BillID,Account,Name,Amount,max(Lang)
FROM Bills 
WHERE Account='abcd'
group by BillID,Account,Name,Amount;

如果在多种语言中存在相同的帐单,则您不会优先使用任何特定语言。以上查询将完美无缺。

编辑:从分组中删除“ID”。 @Phil你是对的.. !!

答案 2 :(得分:4)

 select
 BillID,Account,Name,Amount,max(Lang)
 FROM Bills 
 WHERE Account='abcd'
 group by BillID,Account,Name,Amount;

与user2407394相同,除了groupby中没有ID,因为它也会返回3。

答案 3 :(得分:0)

使用 SELECT DISTINCT 关键字获取不同的值 SELECT DISTINCT ID,BillID,Account,Name,Amount,Lang FROM Bills; 您将获得不同的值。