sql – 根据字段过滤重复的行
发布时间:2021-01-12 09:36:19 所属栏目: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 BYSELECT * FROM ( SELECT b.*,ROW_NUMBER() OVER (PARTITION BY BillID ORDER BY Lang) as num FROM Bills b WHERE Account = 'abcd' ) tbl WHERE num = 1 (编辑:均轻资讯网_我爱站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
相关内容
- sql-server – lt;gt;和!=在SQL Server中性能相同的权威来
- sql-server – SQL Server CASE语句是否评估所有条件或在第
- sql – HQL Join – 加入的路径!过冬
- sql-server – 这个NO JOIN PREDICATE警告我应该感到警惕吗
- 两个SQL COUNT()查询?
- 监控 – Munin – 从数据库加载旧/历史数据以预先填充图表?
- sql-server – 在WCF中处理图像
- sql-server – sp_help中的FixedLenNullInSource是什么意思
- 生成连续日期的sql临时表到左外连接到
- sql-server – 使用T-SQL测试字符串是否为回文结构
站长推荐
- 使用.SQL文件创建MySQL数据库
- 实体框架 – 具有Identity列的SQL Server Compac
- sql – 与在MS Access数据库中加入相关的问题
- 在SQL Server 2008中使用OPENXML存储过程 – INS
- sql-server – 在专用数据库服务器上,为操作系统
- sql-server – 在SQL Server中处理日期
- sql-server – 我的SQL Server是否已修补?
- sql-server – 在SQL Server 2005中创建一个新的
- sql-server – 管理工作室关闭时SQL Server性能不
- sql-server – SQL Server:如何收缩FileStream文
热点阅读

