选择一列DISTINCT SQL
发布时间:2020-12-12 16:17:07 所属栏目:MsSql教程 来源:网络整理
导读:添加:使用SQL Server 2000和2005,所以必须在两者上工作.此外,value_rk不是数字/整数(错误:操作数数据类型uniqueidentifier对于min运算符无效) 有没有办法做单列“DISTINCT”匹配,当我不在乎其他列返回?例: **Table**Value A,Value L,Value PValue A,Value
添加:使用SQL Server 2000和2005,所以必须在两者上工作.此外,value_rk不是数字/整数(错误:操作数数据类型uniqueidentifier对于min运算符无效)
有没有办法做单列“DISTINCT”匹配,当我不在乎其他列返回?例: **Table** Value A,Value L,Value P Value A,Value Q,Value Z 我需要根据第一个行(Value A)中只返回一行.我仍然需要第二和第三列的结果(第二列应该实际上全部匹配,但第三个是唯一的键,我至少需要一个). 这是我到目前为止,虽然它不明显: SELECT value,attribute_definition_id,value_rk FROM attribute_values WHERE value IN ( SELECT value,max(value_rk) FROM attribute_values ) ORDER BY attribute_definition_id 我正在ColdFusion工作,所以如果有一个简单的解决方法,我也是开放的.我试图限制或“分组”第一列“值”. value_rk是我的大问题,因为每个值都是唯一的,但我只需要一个. 注意:value_rk不是一个数字,因此这不工作 更新:我有一个工作版本,它可能比纯SQL版本慢一点,但老实说,任何在这一点上工作的东西比没有更好.它需要第一个查询的结果,执行第二个查询,但将结果限制为一个,并为匹配的值获取匹配的value_rk.像这样: <cfquery name="queryBaseValues" datasource="XXX" timeout="999"> SELECT DISTINCT value,attribute_definition_id FROM attribute_values ORDER BY attribute_definition_id </cfquery> <cfoutput query="queryBaseValues"> <cfquery name="queryRKValue" datasource="XXX"> SELECT TOP 1 value_rk FROM attribute_values WHERE value = '#queryBaseValues.value#' </cfquery> <cfset resourceKey = queryRKValue.value_rk> ... 所以你有它,在ColdFusion中明确选择一个列.任何纯SQL Server 2000/2005的建议仍然很受欢迎:) 解决方法这可能会起作用:SELECT DISTINCT a.value,a.attribute_definition_id,(SELECT TOP 1 value_rk FROM attribute_values WHERE value = a.value) as value_rk FROM attribute_values as a ORDER BY attribute_definition_id ..没有测试. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |