我不能让HoneySQL发出允许我在WHERE子句中使用复合键的SQL。
我想要得到的是: SQL:
SELECT field_id, layer, event_date, is_deleted
FROM event
WHERE
field_id in ('1325629', '1627236', '1673576') AND
layer in ('fha.raw') AND
(field_id,layer,event_date) > ('1627236','fha.raw', '2018-07-23 09:45:07.6-07')
ORDER BY field_id, layer, event_date;HoneySQL:
(-> (sqlh/select :field_id :layer :event_date :is_deleted)
(sqlh/from :event)
(sqlh/merge-where [:in :field_id field-ids])
(sqlh/merge-where (cond (not-empty layers) [:in :layer layers]))
(sqlh/merge-where [:>
[:field_id :layer :event_date]
["1627236" "fha.raw" (c/from-string "2018-07-23T09:45:07.6-07:00")]])
(sqlh/order-by :field_id :layer :event_date)
sql/format)HoneySQL正在产生一些无法工作的东西
["SELECT field_id, layer, event_date, is_deleted FROM event WHERE (((field_id in (?, ?, ?)) AND (layer in (?, ?, ?, ?))) AND field_id(layer, event_date) > 1627236(?, ?)) ORDER BY field_id, layer, event_date"
"1325629"
"1627236"
"1673576"
"fha.abs"
"fha.rank"
"fha.true-color"
"fha.raw"
"fha.raw"
#object[org.joda.time.DateTime 0x4fa79ee8 "2018-07-23T16:45:07.600Z"]]..。它搞错了WHERE子句中的复合键,错误地构建了一个函数调用或其他东西:field_id(layer, event_date)而不是(field_id, layer, event_date)
我该怎么做呢?
这与我之前在ORDER BY子句(How can I make HoneySQL handle order by as a compound key?)中尝试执行相同操作时提出的一个问题有关。事实证明,在复合键方面从未真正得到解决,但确实允许我在其中一个字段上对DESC进行排序。换句话说,我还没有找到如何让HoneySQL在WHERE或ORDER BY子句中执行复合键。
我可以用一点方向。
发布于 2019-03-01 16:10:46
与大多数SQL抽象一样,HoneySQL只适用于标准情况。我相信现在是使用raw语句的好时机。它按原样插入SQL语句,而不对其进行预处理,无论是使用函数还是标记:
(sql/raw "@var := foo.bar")
#sql/raw "@var := foo.bar"在您的情况下,它只是:
...
(sqlh/merge-where
#sql/raw "(field_id,layer,event_date) > ('1627236','fha.raw', '2018-07-23 09:45:07.6-07')")
...而且你很棒。
当然,永远不要将用户的输入传递到原始SQL语句中。
发布于 2019-03-07 02:27:39
您可能需要考虑Walkable,这是另一个具有更具表现力的语言https://walkable.gitlab.io/s-expressions.html的SQL库。
例如,将您的查询转换为Walkable:
(let [field-ids [1 2 3]
layers ["a" "b" "c"]
layer-filters (when (not-empty layers) `([:in :layer ~@layers]))]
`[(:event/all {:filters [:and [:in :event/field-id ~@field-ids]
~@layer-filters
[:> [:tuple :event/field-id :event/layer :event/event-date]
[:tuple "1627236" "fha.raw" "2018-07-23T09:45:07.6-07:00"]]]
:order-by [:event/field-id :event/layer :event/event-date]}
[:event/field-id :event/layer :event/event-date :event/is-deleted])])https://stackoverflow.com/questions/54772969
复制相似问题