一尘不染

根据字段过滤重复的行

sql

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

例如:

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个账单,其账单ID为0003,SPA或ENG版本为0001,但不能同时获取两者。

通过查询将是什么?

谢谢

编辑:我不能依靠总是在那里的特定语言。例如,我不能说,SELECT * FROM Bills WHERE Account='abcd' ANDLang='ENG'因为有时帐单可能只使用一种语言,而不是ENG,有时可能使用多种语言的任何组合。


阅读 130

收藏
2021-03-17

共1个答案

一尘不染

也许最简单的方法是使用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
2021-03-17