加入收藏 | 设为首页 | 会员中心 | 我要投稿 衡阳站长网 (https://www.0734zz.cn/)- 数据集成、设备管理、备份、数据加密、智能搜索!
当前位置: 首页 > 站长学院 > MsSql教程 > 正文

sql – 根据字段过滤重复的行

发布时间:2021-01-12 07:28:08 所属栏目:MsSql教程 来源:网络整理
导读:我有几个记录(账单)基本上是彼此重复的,除了一个字段,它代表账单所在的语言. 例如: ID,BillID,Account,Name,Amount,Lang1,0001,abcd,John Smith,10.99,ENG2,0002,qwer,Jane Doe,9.99,ENG3,SPA4,0003,4.99,CHI 所有字段都是字符串,ID除外,它是一个自动编号.

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

例如:

ID,BillID,Account,Name,Amount,Lang
1,0001,abcd,John Smith,10.99,ENG
2,0002,qwer,Jane Doe,9.99,ENG
3,SPA
4,0003,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,有时可能是多种语言的任何组合.

解决方法

可能最简单的方法是使用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

(编辑:衡阳站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读