我有几个记录(账单)基本上是彼此重复的,除了一个字段,它代表账单所在的语言.
例如:
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
Run Code Online (Sandbox Code Playgroud)
所有字段都是字符串,ID除外,它是一个自动编号.
在我的SQL选择中,我有
SELECT *
FROM Bills
WHERE Account='abcd'
Run Code Online (Sandbox Code Playgroud)
它总共返回3行,但同一帐单有2行.我需要为特定帐户返回唯一的帐单.因此,在上面的场景中,我想检索2个账单,其中包含billID 0003和SPA或ENG版本的0001,但不是两者.
什么会被查询?
谢谢
编辑:我不能依赖于一直存在的特定语言.例如,我不能说SELECT * FROM Bills WHERE Account='abcd' AND Lang='ENG'因为有时一个法案可能只有一种语言,而不是ENG,有时可能是几种语言的任何组合.
Eri*_*lje 14
可能最简单的方法是使用ROW_NUMBER和PARTITION 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
Run Code Online (Sandbox Code Playgroud)
select
ID,BillID,Account,Name,Amount,max(Lang)
FROM Bills
WHERE Account='abcd'
group by BillID,Account,Name,Amount;
Run Code Online (Sandbox Code Playgroud)
鉴于如果有多种语言的相同账单,您不会优先考虑任何特定语言.以上查询将完美.
编辑:从组中删除"ID".@Phil你是对的.. !!
select
BillID,Account,Name,Amount,max(Lang)
FROM Bills
WHERE Account='abcd'
group by BillID,Account,Name,Amount;
Run Code Online (Sandbox Code Playgroud)
与 user2407394 相同,除了 groupby 中没有 ID,因为它也会返回 3。
| 归档时间: |
|
| 查看次数: |
29538 次 |
| 最近记录: |