微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

选择一列DISTINCT SQL

添加:使用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

..没有测试.

原文地址:https://www.jb51.cc/mssql/82936.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐