如何从next.jdbc/plan
的结果中直接实现行,而不进行任何转换?
标识符不起作用
(require '[next.jdbc :as jdbc])
(def sql-params
["SELECT column1
FROM (VALUES (1, 1, 1),
(2, 2, 2),
(3, 3, 3)) AS _"])
(into []
(map identity)
(jdbc/plan db-spec
sql-params))
;=> [{row} from `plan` -- missing `map` or `reduce`?
; {row} from `plan` -- missing `map` or `reduce`?
; {row} from `plan` -- missing `map` or `reduce`?]
如果行以映射(默认)形式表示,#(into {} %)
起作用
(into []
(map #(into {} %))
(jdbc/plan db-spec
sql-params))
;=> [{:column1 1} {:column1 2} {:column1 3}]
如果行以向量(builder-fn
)表示,可以使用vec
(require '[next.jdbc.result-set :as rs])
(into []
(map vec)
(jdbc/plan db-spec
sql-params
{:builder-fn rs/as-arrays}))
;=> [[1] [2] [3]]
是否有任何 xform 可以涵盖映射和向量的行实现?
或者我应该使用plan
之外的东西进行懒加载结果集读取?