我可以在Korma的两个字段上使用distinct吗



我有一个包含四个字段的表: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`"

SQL关键字DISTINCT在大多数(所有?)数据库中对整列进行操作,包括MySQL和SQL Server。因此,至少在那些数据库中,没有办法在字段的子集上使用DISTINCT

一个不同的查询,可能像SQL中建议的那样-';与众不同';只基于某些列?可能会得到你需要的东西。

相关内容

  • 没有找到相关文章

最新更新