當我寫入到SQLite表中時,我用http-kit異步行爲進行了干預。異步clojure http-kit客戶端與回調寫入數據庫sqlite3
數據庫的I/O取決於我是將代碼發送到boot
repl還是將其作爲boot
腳本運行。 I/O只能在repl情況下進行。我錯過了什麼?這是我的代碼:
#!/usr/bin/env boot
(defn deps [new-deps]
(boot.core/merge-env! :dependencies new-deps))
(deps '[
[http-kit "2.2.0"]
[org.clojure/core.async "0.2.395"]
[org.clojure/java.jdbc "0.7.0-alpha1"]
[org.xerial/sqlite-jdbc "3.16.1"]
[org.slf4j/slf4j-nop "1.7.22"]
])
(require
'[org.httpkit.client :as http]
'[clojure.java.jdbc :as jdbc]
)
(def db-spec
{:classname "org.sqlite.JDBC"
:subprotocol "sqlite"
:subname "sqlite.db"})
;(jdbc/db-do-commands
;db-spec
;(jdbc/create-table-ddl "test" [[:msg :text]]))
(def ins! (partial jdbc/insert! db-spec "test"))
(http/get "http://locahost" {} (fn [_] (ins! {:msg "repl"})))
(defn -main []
(println (System/getProperty "user.dir"))
(http/get "http://locahost" {} (fn [_] (ins! {:msg "exec"}))))
感謝
能否請你解決你的問題,因爲它沒有按」工作?它有幾個問題:它缺少clojure.java.jdbc依賴關係,並指定了「web」依賴關係,這對您的問題並不重要,並且在公共maven回購站中不可用。 –