edbc統(tǒng)一數(shù)據(jù)庫訪問接口
edbc 是 Emacs-Lisp Database Connectivity 的縮 寫 ,是從 Emacs-CGI 項目中獨立出來的一個子項目,為 Emacs Lisp 訪問數(shù)據(jù)庫提供簡潔、統(tǒng)一的接口!
在其他語言(比如Java)中訪問數(shù)據(jù)庫,最終SQL語句都會轉(zhuǎn)成字符串的形式,即涉及到字符串拼接、引號轉(zhuǎn)義等丑陋的代碼。在 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)))
目前 EDBC 已支持 Sqlite 和 MySQL 兩種數(shù)據(jù)庫。用戶參考 edbc-mysql.el 可以很輕松支持其他數(shù)據(jù)庫。
評論
圖片
表情
