我可以在Korma的两个领域使用distinct吗?

时间:2015-03-18 13:03:36

标签: korma

我有一个包含四个字段的表格:abcd

我想要一个类似的查询:

select distinct a, b from t;

文档建议类似

(k/select my-table
          (k/modifier "DISTINCT")
          (k/fields :a :b))

但生成的SQL就像:

SELECT distinct a, b, c, d FROM my_table;

我想要的是:

SELECT distinct a, b FROM my_table;

如何将distinct修饰符限制为仅两个字段?

尝试使用不同的修饰符值(例如DISTINCT (a, b))会导致错误的SQL查询。

这是一个完整的例子:

(k/defentity my-table (k/entity-fields :a :b :c :d))

(k/sql-only (k/select my-table (k/fields :a :b)
                               (k/modifier "DISTINCT")))

"SELECT DISTINCT `my-table`.`a`,
                 `my-table`.`b`,
                 `my-table`.`c`,
                 `my-table`.`d`,
                 `my-table`.`a`,
                 `my-table`.`b` FROM `my-table`"

1 个答案:

答案 0 :(得分:0)

SQL关键字DISTINCT在大多数(所有?)数据库的整个列上运行,包括MySQL和SQL Server。因此,至少在这些数据库中,无法在字段子集上使用DISTINCT

其他查询(如SQL - 'DISTINCT' based on only some columns?中建议的查询可能会为您提供所需的查询。