加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-13 16:14:30 所属栏目:百科 来源:网络整理
导读:我想从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] (sq
我想从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)))))

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读