微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

postgresql – 如何从clojure.java.jdbc中删除或创建数据库?

我想从clojure. java.jdbc创建/删除数据库.这失败了:
(require '[clojure.java.jdbc :as sql])

(def db
  {:classname "org.postgresql.Driver"
   :subprotocol "postgresql"
   :subname "//localhost/postgres"
   :user "postgres"})

(defn drop-database [name]
  (sql/do-commands (str "drop database " name)))

(sql/with-connection db 
  (drop-database "db_name"))

因为do-commands启动一个事务,显然你不能在事务中删除或创建数据库.有任何想法吗?

谢谢!

获取do-commands( here)的源代码删除对事务的调用
(defn drop-database [name]
  (sql/with-connection db
    (with-open [s (.createStatement (sql/connection))]
      (.addBatch s (str "drop database " name))
      (seq (.executeBatch s)))))

原文地址:https://www.jb51.cc/postgresql/191929.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐