two more possible solutions to #495

Signed-off-by: Sean Corfield <sean@corfield.org>
This commit is contained in:
Sean Corfield 2024-01-06 22:35:02 -08:00
parent ac947b1543
commit 1291b328d0
No known key found for this signature in database
4 changed files with 41 additions and 6 deletions

View file

@ -1,2 +1 @@
{:lint-as {}
{honeysql.helpers/defhelper clojure.core/defn}}

View file

@ -3,6 +3,7 @@
* 2.5.next in progress * 2.5.next in progress
* Address [#520](https://github.com/seancorfield/honeysql/issues/520) by expanding how `:inline` works, to support a sequence of arguments. * Address [#520](https://github.com/seancorfield/honeysql/issues/520) by expanding how `:inline` works, to support a sequence of arguments.
* Fix [#518](https://github.com/seancorfield/honeysql/issues/518) by moving temporal clause before alias. * Fix [#518](https://github.com/seancorfield/honeysql/issues/518) by moving temporal clause before alias.
* Address [#495](https://github.com/seancorfield/honeysql/issues/495) by adding (experimental) `format&` and `formatv` macros -- purely for discussion: may be removed in a subsequent release!
* Implemented `CREATE INDEX` [#348](https://github.com/seancorfield/honeysql/issues/348) via PR [#517](https://github.com/seancorfield/honeysql/pull/517) [@dancek](https://github.com/dancek). * Implemented `CREATE INDEX` [#348](https://github.com/seancorfield/honeysql/issues/348) via PR [#517](https://github.com/seancorfield/honeysql/pull/517) [@dancek](https://github.com/dancek).
* 2.5.1103 -- 2023-12-03 * 2.5.1103 -- 2023-12-03

View file

@ -1,4 +1,4 @@
;; copyright (c) 2020-2023 sean corfield, all rights reserved ;; copyright (c) 2020-2024 sean corfield, all rights reserved
(ns honey.sql (ns honey.sql
"Primary API for HoneySQL 2.x. "Primary API for HoneySQL 2.x.
@ -29,6 +29,7 @@
it uppercase and replaces - with space). " it uppercase and replaces - with space). "
(:refer-clojure :exclude [format]) (:refer-clojure :exclude [format])
(:require [clojure.string :as str] (:require [clojure.string :as str]
[clojure.template]
[honey.sql.protocols :as p])) [honey.sql.protocols :as p]))
;; default formatting for known clauses ;; default formatting for known clauses
@ -2100,6 +2101,33 @@
[dsl & params] [dsl & params]
(format dsl {:params (zipmap (map (comp keyword str inc) (range)) params)})) (format dsl {:params (zipmap (map (comp keyword str inc) (range)) params)}))
(defmacro format&
"Experimental implementation of https://github.com/seancorfield/honeysql/issues/495
Implicitly treats any locally bound symbol as a variable to be substituted
in the symbolic SQL expression.
(let [x 42 y 13]
(format& '{select * from table where (= x y)}))
=> SELECT * FROM table WHERE (42 = 13)"
[dsl & opts]
(let [syms (vec (keys &env))]
`(honey.sql/format (clojure.template/apply-template '~syms ~dsl ~syms) ~@opts)))
(defmacro formatv
"Experimental implementation of https://github.com/seancorfield/honeysql/issues/495
Treats the specified vector of symbols as variables to be substituted
in the symbolic SQL expression.
(let [x 42 y 13]
(formatv [x] '{select * from table where (= x y)}))
=> SELECT * FROM table WHERE (42 = y)"
[syms sql & opts]
`(honey.sql/format (clojure.template/apply-template '~syms ~sql ~syms) ~@opts))
(defn set-dialect! (defn set-dialect!
"Set the default dialect for formatting. "Set the default dialect for formatting.
@ -2367,8 +2395,15 @@
(sql/register-fn! :foo foo-formatter) (sql/register-fn! :foo foo-formatter)
(sql/format {:select [:*], :from [:table], :where [:foo [:+ :a 1]]}) (sql/format {:select [:*], :from [:table], :where [:foo [:+ :a 1]]})
(sql/formatf '{select * from table where (foo (+ a 1))}) (sql/format '{select * from table where (foo (+ a 1))})
(sql/formatf '{select * from table where (foo (+ a ?1))} 42) (let [v 42]
(sql/formatf '{select * from table where (foo (+ a ?1))} v))
(let [v 42]
(sql/format& '{select * from table where (foo (+ a v))}))
(let [v 42]
(sql/formatv [v] '{select * from table where (foo (+ a v))}))
(sql/format '{select * from table where (foo (+ a ?v))}
{:params {:v 42}})
(sql/format {:update [:user :u] (sql/format {:update [:user :u]
:set {:email :u2.email :set {:email :u2.email

View file

@ -1,4 +1,4 @@
;; copyright (c) 2021-2023 sean corfield, all rights reserved ;; copyright (c) 2021-2024 sean corfield, all rights reserved
(ns honey.sql-test (ns honey.sql-test
(:refer-clojure :exclude [format]) (:refer-clojure :exclude [format])