This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2021-06-16
Channels
- # admin-announcements (1)
- # announcements (1)
- # babashka (130)
- # beginners (120)
- # calva (11)
- # cider (5)
- # clj-kondo (9)
- # cljsrn (17)
- # clojure (63)
- # clojure-australia (1)
- # clojure-canada (21)
- # clojure-europe (37)
- # clojure-israel (4)
- # clojure-uk (6)
- # clojurescript (170)
- # conjure (5)
- # core-async (23)
- # cursive (16)
- # datomic (4)
- # defnpodcast (1)
- # emacs (5)
- # fulcro (1)
- # gis (2)
- # graalvm (31)
- # graphql (4)
- # helix (6)
- # honeysql (16)
- # jobs-discuss (3)
- # juxt (1)
- # lsp (7)
- # malli (20)
- # meander (12)
- # missionary (6)
- # off-topic (50)
- # pathom (4)
- # re-frame (4)
- # react (1)
- # ring (2)
- # shadow-cljs (63)
- # spacemacs (2)
- # sql (15)
- # testing (6)
- # vim (8)
- # xtdb (7)
Oh I see, just pass in a keyword: :desc-nulls-last
which sql-kw
would convert to DESC NULLS LAST
I see that honeysql v1 qualify
was removed. It was quite handy for us, I've come up with a quick replacement:
(defn- qualify
"Replace honeysql v1 qualify function, that takes a table and column
and joins them together."
[table column]
(keyword (hsql/format-entity (keyword (name table) (name column)))))
I was just wondering if there was something wrong with the original? I could copy that code.Encouraging pervasive use of namespaced keywords is the reason perhaps?
What purpose do qualified names serve in SQL?
So we use a lot of WITH statements that we later join to. Sometimes more than once with different table names. So the table name is dynamic. If you want to refer to a specific column you need to write it as table.column which is what the qualify function would give us
So you’re round-tripping through qualified keywords for that? I guess I’m having a hard time imagining what the code looks like for this to be needed… Can you show a (simplified) example?
I’m on the phone but imagine that I have a base query map that I keep adding where clauses to (users adding filters etc) Some of the where clauses need additional with and left-join clauses. The with, left-join and where clauses must share the same table name. The table name is dynamic as a filter might be repeated. So all the column references need to be qualified at runtime with the dynamic table name.
Note, I don’t care about namespaced Clojure keywords at all. All I want is a honeysql function that given a table and a column will construct the correct keyword (to be later escaped properly) for an “absolute” column reference.
My sample code took advantage that format-entity uses namespaced keywords to generate the escaped column reference.
:some_alias.some_col
when you have [:table :some_alias]
to alias table
to some_alias
?
And :some_alias
is the dynamic part here (not really the table name)?
So I think you just want (keyword (name the-alias) (name column))
and then HoneySQL will take care of formatting that? (you don’t need to call format-entity
and convert back to a keyword) What am I missing?
Right, so there is a convention that I’m missing. In all of our hand written columns we use dot as a separator - alias.some_column - but you’re saying that namespaced keywords also would be equivalent; alias/some_column as far as honeysql is concerned?
In v1, you needed to specify :namespace-as-table? true
as an option — that has become the default in v2:
dev=> (sql/format {:select [:foo/bar] :from [:foo] :where [[:= :foo/id 42]]})
["SELECT foo.bar FROM foo WHERE (foo.id = ?)" 42]
dev=>