15

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

例如:

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' AND Lang='ENG',因为有时账单可能只有一种语言,但不是ENG,有时可能是多种语言的任意组合。

4

4 回答 4

20

可能最简单的方法是使用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
于 2013-06-20T18:58:41.380 回答
9
select
ID,BillID,Account,Name,Amount,max(Lang)
FROM Bills 
WHERE Account='abcd'
group by BillID,Account,Name,Amount;

鉴于如果有多种语言的相同账单,您不会优先考虑任何特定语言。上述查询将完美运行。

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

于 2013-06-20T18:58:11.140 回答
5
 select
 BillID,Account,Name,Amount,max(Lang)
 FROM Bills 
 WHERE Account='abcd'
 group by BillID,Account,Name,Amount;

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

于 2013-06-20T19:06:29.097 回答
1

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

于 2018-11-03T09:51:27.410 回答