This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2021-04-14
Channels
- # babashka (53)
- # beginners (158)
- # calva (25)
- # cider (21)
- # clara (1)
- # clj-kondo (12)
- # cljsrn (6)
- # clojure (94)
- # clojure-australia (2)
- # clojure-bay-area (6)
- # clojure-europe (40)
- # clojure-nl (10)
- # clojure-spec (16)
- # clojure-uk (18)
- # clojurescript (95)
- # cursive (14)
- # data-science (1)
- # datascript (6)
- # datomic (18)
- # depstar (2)
- # duct (36)
- # emacs (15)
- # events (4)
- # fulcro (16)
- # graalvm (10)
- # helix (25)
- # honeysql (6)
- # jackdaw (4)
- # jobs (2)
- # leiningen (24)
- # lsp (4)
- # malli (10)
- # off-topic (3)
- # pathom (3)
- # polylith (19)
- # practicalli (4)
- # prelude (1)
- # re-frame (6)
- # reagent (13)
- # reitit (3)
- # remote-jobs (10)
- # ring (12)
- # ring-swagger (2)
- # shadow-cljs (54)
- # testing (17)
- # tools-deps (10)
- # xtdb (14)
Is anyone using postgres enums with honeySQL? So far the only way I found to make it work was to use either [:inline "enumValue"]
or (types/as-other "enumValue")
, in both cases the downside is that it involves modifying the query arguments, and keywords can't be used without an extra step to turn them into strings
Could you write your own helper to handle the keyword conversion for you? e.g.
(defn clj-pg-enum
[kw]
[:inline (name kw)])
yes that is what I have
(defn enum [k]
(types/as-other (name k)))
I wouldn't recommend the inline solution it's not the same, with as-other it's a ?
in your prepared statement, with inline
it's part of itI've added casts in the enum definition:
DO $$ BEGIN
CREATE TYPE idea_state AS ENUM ('draft', 'publish');
CREATE CAST (varchar AS idea_state) WITH INOUT AS ASSIGNMENT;
EXCEPTION
WHEN duplicate_object THEN null;
END $$;
But I was recently told that postgres enums are dangerous because you cannot add new values without dropping the enum, which is difficult to do when you already have data that point to the enum.
https://blog.yo1.dog/updating-enum-values-in-postgresql-the-safe-and-easy-way/ what you were told is not correct, adding is easy, updating is only since 9.6 and removing involves renaming / creating a new one / migrating