This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2020-06-03
Channels
- # babashka (17)
- # beginners (166)
- # calva (97)
- # cider (4)
- # clara (2)
- # clj-kondo (46)
- # cljsrn (5)
- # clojure (334)
- # clojure-canada (1)
- # clojure-dev (144)
- # clojure-europe (14)
- # clojure-germany (5)
- # clojure-nl (10)
- # clojure-spec (1)
- # clojure-uk (46)
- # clojurescript (50)
- # conjure (1)
- # core-async (52)
- # core-typed (5)
- # cursive (3)
- # datomic (3)
- # emacs (11)
- # figwheel (16)
- # figwheel-main (9)
- # fulcro (29)
- # graalvm (19)
- # graphql (14)
- # helix (46)
- # hoplon (4)
- # hugsql (2)
- # jobs (2)
- # jobs-discuss (1)
- # juxt (15)
- # kaocha (6)
- # off-topic (9)
- # pedestal (7)
- # portkey (7)
- # re-frame (10)
- # reagent (29)
- # shadow-cljs (13)
- # spacemacs (70)
- # sql (13)
- # tools-deps (26)
- # xtdb (23)
I’m refactoring from clojure.java.jdbc to next.jdbc and i had “truncate” utility using db-do-commands
to issue sequence of TRUNCATE TABLE statements.
db-do-command seems to use (.addBatch stmt cmd)
and then execute them as batch. Now going through next.jdbc docs and eventually source, for now the closest I’ve found is p/execute-batch!
, but it seems to assume the batch contains prepared statements with params.. I tried TRUNCATE TABLE ?
and gave seq of tables, but it seems it’s not possible to use ? in place of table name. I don’t know if it’s that I’m noob, but looking from my problems perspective, the p/execute-batch!
looks too opinionated because it uses set-parameters
What would be the next.jdbc way to do this? Manually use addBatch
to add the plain TRUNCATE strings and then do .executeBatch
? The migration guide mentions that execute!
could replace most uses of db-do-commands
, but I can’t get my head around about how refactor this (rather simple) case 😄
I guess with something like (run! #(next/execute! conn [%]) [..command-strs…])
I can get forward, but I’m pleased to hear other suggestions too!
@snurppa Is this just a single TRUNCATE TABLE foo
command? If so, just use execute-one!
(or execute!
) as the docs tell you in the Getting Started guide.
That's why I had db-do-commands before, as it batched them. But idk if it matters, I guess I could do those in simple doseq as well? Just looking for the idiomatic way to do it in next.jdbc as I'm learning it 😊 And thanks for your efforts with lib and everything in the community @U04V70XH6!
If you have multiple commands, (run! #(jdbc/execute-one! conn [%]) ["list" "of" "commands"]))
seems reasonable to me.
If you really want them executed in a batch, you'd need to use Statement
, not PreparedStatement
, so something like this would work:
(defn do-commands [conn & cmds]
(let [stmt (prep/statement conn)]
(run! #(.addBatch stmt %) cmds)
(.executeBatch stmt)))
That's not too bad in terms of interop.(untested, but I think that should work)
Yeah, that seems to work:
user=> (require '[next.jdbc.prepare :as prep])
nil
user=> (require '[next.jdbc :as jdbc])
nil
user=> (defn do-commands [conn & cmds]
(let [stmt (prep/statement conn)]
(run! #(.addBatch stmt %) cmds)
(.executeBatch stmt)))
#'user/do-commands
user=> (with-open [conn (jdbc/get-connection db-spec)]
(do-commands conn "TRUNCATE user" "TRUNCATE status" "TRUNCATE transaction"))
#object["[I" 0x7b48b933 "[I@7b48b933"]
That's a Java int array but it's just going to contain three zeros so its value isn't important ^ @snurppaI'll open a ticket to add that but I don't think do-db-commands
was very widely used... so I may just add that code to the migration guide.
I think the (prep/statement)
call should use with-open
rather than let
but haven't investigated that. It was just a quick example.