我有一个包含四个字段的表格:a
,b
,c
和d
。
我想要一个类似的查询:
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`"
答案 0 :(得分:0)
SQL关键字DISTINCT
在大多数(所有?)数据库的整个列上运行,包括MySQL和SQL Server。因此,至少在这些数据库中,无法在字段子集上使用DISTINCT
。
其他查询(如SQL - 'DISTINCT' based on only some columns?中建议的查询可能会为您提供所需的查询。