0

为了避免处理 java 的日期和时间对象,我使用了 clj-time。当我将它与 korma 的 sqlite3 助手一起使用时,它工作正常,但是当我做类似的事情时

(insert posts (values {:name "name" :due_date (date-time 2014)}))

我被告知系统无法推断对象类型。

我一直在四处寻找并询问,似乎 clojure.java.jdbc 支持一个名为 ISQLValue 的协议正是为了处理这样的事情。它用于扩展对象,以便它们可以在数据库中表示自己。然而,最新版本的 korma 使用 CJJ 的 0.2 版本。

每次需要将日期时间对象呈现给 psql 数据库时,是否有任何替代方法可以使用 clj-time.coerce/to-sql-date?

4

1 回答 1

1

我正在使用以下功能

clj-time.coerce/to-sql-time

它对我来说很好。我测试了插入查询的空运行

(use :reload-all 'clj-time.core)
(use :reload-all 'clj-time.coerce)

接着

(defn sql-now[]
  "Returns now in sql time formate"
  (to-sql-time (now)))

接着

(use :reload-all 'korma.core)

接着

(dry-run (insert :users (values {:email "afdbsk@jasdfgkj.cdosjf" :created_at (sql-now)})))

输出是

dry run :: INSERT INTO "users" ("created_at", "email") VALUES (?, ?) :: [#inst "2014-09-15T06:32:24.498000000-00:00" afdbsk@jasdfgkj.cdosjf]
=> [{nil 1}]

它对我来说很好,如果它完全满足您的要求,请检查这些。如果您有任何疑问,请回复?

对我来说很好

于 2014-09-15T06:45:26.380 回答