如何从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`?]
如果行以映射形式表示(默认),可以使用(code)#(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之外的lazy结果集读取方式?