如何直接将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
之外的方法来以懒方式读取结果集?