Emacs Lisp 統一數據庫訪問接口:edbc

jopen 11年前發布 | 13K 次閱讀 數據庫訪問 持久層框架

edbc 是 Emacs-Lisp Database Connectivity 的縮  ,是從 Emacs-CGI 項目中獨立出來的一個子項目,問 Emacs Lisp 訪問數據庫提供簡潔、統一的接口!

在其他語言中(比如Java)中訪問數據庫,最終SQL語句都是以字符串的形式提供的,會出現字符串拼接、引號轉移等丑陋的代碼。在 edbc 中,利用 Lisp 強大的可擴展性,直接把 SQL 嵌到語言中,就像它原生就支持的一樣。例如下面連接 Sqlite 的例子:

(edbc-with-connect ((url "users.db"))
  (let ((id 1)
        (name "Joe")
        (nickname "redraiment"))
    ; Purge table
    (edbc delete from users)
    ; Equals insert into users (id, name) values (1, 'Joe') on sqlite
    (edbc insert into users (id, name) values (:id, :name))
    ; Equals update users set name = 'redraiment' where id = 1 on sqlite
    (edbc update users set name = :nickname where id = :(identity id))
    ; Returns ((("id" . "1") ("name" . "redraiment")))
    (edbc select * from users)))

目前已經支持 Sqlite 和 MySQL 兩種數據庫。并且,參考 edbc-mysql.el 可以很輕松支持其他任意數據庫。

項目主頁:http://www.baiduhome.net/lib/view/home/1356484352526

 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!