小编典典

选择一列DISTINCT SQL

sql

补充:使用SQL Server
2000和2005,因此必须同时使用两者。另外,value_rk也不是数字/整数(错误:操作数数据类型uniqueidentifier对min运算符无效)

当我不在乎返回的其他列时,是否有一种方法可以使单个列“ DISTINCT”匹配?例子:

**Table**
Value A, Value L, Value P
Value A, Value Q, Value Z

我只需要根据第一个(值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建议:)


阅读 207

收藏
2021-03-17

共1个答案

小编典典

这可能有效:

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

..未经测试。

2021-03-17