我有一个包含四个字段的表: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`"
SQL关键字DISTINCT
在大多数(所有?)数据库中对整列进行操作,包括MySQL和SQL Server。因此,至少在那些数据库中,没有办法在字段的子集上使用DISTINCT
。
一个不同的查询,可能像SQL中建议的那样-';与众不同';只基于某些列?可能会得到你需要的东西。