面向对象的数据库db4o: 安装并使用db4o
為什么80%的碼農都做不了架構師?>>> ??
下載和安裝db4o
db4o 所有最新的版本都可以直接在官方網站上下載,進入 db4o 的下載頁面,我們可以看到最新的 for Java 穩定版本,包括 JAR、源代碼、入門文檔、API 等內容的完整的打包文件只有 6 MB,db4o 還有一個對象數據庫管理工具 ObjectManager,目前版本是 1.8。
接著在 Eclipse 中新建 Java 項目,把 db4o 對象數據庫引擎包 db4o-8.0.249.16098-all-java5.jar 導入進項目。由于 db4o 支持多種版本的 JDK,除了 for JDK 5.0 的 db4o-8.0.249.16098-all-java5.jar 外,還有 for JDK 1.1、1.2-1.4 的 JAR 包,以適應多種環境。與 Hibernate、iBATIS SQL Maps 相比,db4o 更加自然,無需過多地引用第三方支持庫。
db4o的包結構?
db4o 怎樣進行對象持久化呢?通過瀏覽目錄可以發現,與傳統的 RDBMS 一樣,db4o 也有自己的數據庫文件, 在 db4o 中數據庫文件的后綴名是“*.yap”。讓我們先來了解一下 db4o 對象數據庫引擎的主要包結構:
com.db4o
com.db4o 包含了使用 db4o 時最經常用到的功能。兩個最重要的接口是 com.db4o.Db4o 和 com.db4o.ObjectContainer。com.db4o.Db4o 工廠是運行 db4o 的起點,這個類中的靜態方法可以開啟數據庫文件、啟動服務器或連接一個已經存在的服務器,還可以在開啟數據庫之前進行 db4o 環境配置。com.db4o.ObjectContainer 接口很重要,開發過程中 99% 的時間都會用到它,ObjectContainer 可在單用戶模式下作為數據庫實例,也可作為 db4o 服務器的客戶端。每個 ObjectContainer 實例都有自己的事務。所有的操作都有事務保證。當打開 ObjectContainer,就已經進入事務了,commit() 或 rollback() 時,下一個事務立即啟動。每個 ObjectContainer 實例維護它自己所管理的已存儲和已實例化對象,在需要 ObjectContainer 的時候,它會一直保持開啟狀態,一旦關閉,內存中數據庫所引用的對象將被丟棄。com.db4o.ext
你也許想知道為什么在 ObjectContainer 中只能看見很少的方法,原因如下:db4o 接口提供了兩個途徑,分別在 com.db4o 和 com.db4o.ext 包中。這樣做首先是為了讓開發者能快速上手;其次為了讓其他產品能更容易的復制基本的 db4o 接口;開發者從這一點上也能看出 db4o 是相當輕量級的。每個 com.db4o.ObjectContainer 對象也是 com.db4o.ext.ExtObjectContainer 對象??梢赞D換成 ExtObjectContainer 獲得更多高級特性。com.db4o.config
com.db4o.config 包含了所有配置 db4o 所需的類。com.db4o.query
com.db4o.query 包包含了構造“原生查詢, NQ(Native Queries)”所需的 Predicate 類。NQ 是 db4o 最主要的查詢接口。
初始化數據庫
db4o 提供兩種運行模式,分別是本地模式和服務器模式。本地模式是指直接在程序里打開 db4o 數據庫文件進行操作:
Db4oEmbedded.openFile(Db4oEmbedded.newConfiguration(),?"auto.yap");
而服務器模式則是客戶端通過 IP 地址、端口以及授權口令來訪問服務器:
服務器端:
ObjectServer?server?=?Db4oClientServer.openServer("auto.yap",?1212); server.grantAccess("admin",?"1");客戶端:
//?ip為服務器的ip地址 Db4oClientServer.openClient(ip,?1212,?"admin",?"1");需要注意的是db4o會自動創建數據庫文件,但是并不會創建數據庫文件目錄,比如我想創建數據庫文件"/export/db4o/auto.yap",db4o并不會自動創建"/export/db4o"目錄 ,所以創建數據庫文件時最好初始化下數據庫目錄:
private?void?initDBFile(String?dbName)?{File?file?=?new?File(dbName);if?(file.exists())?{return;}List<File>?fList?=?new?ArrayList<File>();File?pFile?=?file.getParentFile();while?(!pFile.exists())?{fList.add(pFile);pFile?=?pFile.getParentFile();}for?(int?i?=?fList.size()?-?1;?i?>=?0;?i--)?{File?f?=?fList.get(i);f.mkdir();} }
使用數據庫
上面介紹的兩種方式都可以得到 ObjectContainer 實例,就目前Java EE的分布式的應用環境來看,服務器模式更有現實意義;而本地模式更適合于單服務器應用。因為分布式模式比較常用,本文在下面的例子都將采用分布式模式。
在下面的例子中,會使用一個UserVO對象,然后介紹db4o對該對象的CRUD。
? UserVO對象
public?class?UserVO?implements?Serializable?{private?static?final?long?serialVersionUID?=?-9129148024922569814L;private?String?userName;private?String?password;public?UserVO()?{}public?UserVO(String?userName,?String?password)?{this.userName?=?userName;this.password?=?password;}public?String?getPassword()?{return?password;}public?void?setPassword(String?password)?{this.password?=?password;}public?String?getUserName()?{return?userName;}public?void?setUserName(String?userName)?{this.userName?=?userName;}@Overridepublic?boolean?equals(Object?obj)?{if?(this?==?obj)?{return?true;}if?(!(obj?instanceof?UserVO))?{return?false;}UserVO?other?=?(UserVO)?obj;if?(!(userName?==?null???other.userName?==?null?:?userName.equals(other.userName))){return?false;}if?(!(password?==?null???other.password?==?null?:?password.equals(other.password))){return?false;}return?true;}@Overridepublic?int?hashCode()?{final?int?prime?=?31;int?result?=?17;result?=?prime?*?result?+?((userName?==?null)???0?:?userName.hashCode());result?=?prime?*?result?+?((password?==?null)???0?:?password.hashCode());return?result;}@Overridepublic?String?toString()?{return?"UserVO?[userName="?+?userName?+?",?password="?+?password?+?"]";} }增加(Create)
public?static?void?main(String[]?args)?{UserVO?vo?=?new?UserVO("admin",?"1");//?打開數據庫,ip為服務器ipObjectContainer?db?=?Db4oClientServer.openClient(ip,?1212,?"admin",?"1");try?{//?存儲數據db.store(vo);//?提交事務db.commit();}?catch?(Exception?e)?{//?出現異常則回滾db.rollback();}?finally?{//?關閉連接db.close();} }讀取(Retrieve)
public?static?void?main(String[]?args)?{//?打開數據庫ObjectContainer?db?=?Db4oClientServer.openClient(ip,?1212,?"admin",?"1");try?{//?構造查詢對象Query?query?=?db.query();//?設置被約束實例query.constrain(UserVO.class);//?設置被約束實例的字段和約束條件query.descend("userName").constrain("admin");//?查詢對象ObjectSet<UserVO>?list?=?query.execute();//?do?something?with?list}?finally?{//?關閉連接db.close();} }更新(Update)
public?static?void?main(String[]?args)?{//?打開數據庫ObjectContainer?db?=?Db4oClientServer.openClient(ip,?1212,?"admin",?"1");try?{ObjectSet<UserVO>?result?=?db.query(new?Predicate<UserVO>()?{private?static?final?long?serialVersionUID?=?1554763863522546547L;public?boolean?match(UserVO?vo)?{//?匹配userName為admin的UserVOreturn?vo.getUserName().equals("admin");}});if?(result.size()?!=?1)?{throw?new?RuntimeException("size?does?not?matched.");}UserVO?vo?=?result.next();//?修改passportvo.setPassword("0");db.store(vo);db.commit();}?catch?(Exception?e)?{db.rollback();}?finally?{//?關閉連接db.close();} }刪除(Delete)
public?static?void?main(String[]?args)?{UserVO?vo?=?new?UserVO("admin",?"1");//?打開數據庫ObjectContainer?db?=?Db4oClientServer.openClient(ip,?1212,?"admin",?"1");try?{ObjectSet<UserVO>?result?=?db.query(new?Predicate<UserVO>()?{private?static?final?long?serialVersionUID?=?-4397123083792023957L;public?boolean?match(UserVO?vo)?{//?匹配userName為admin的UserVOreturn?vo.getUserName().equals("admin");}});if?(result.size()?!=?1)?{throw?new?RuntimeException("size?does?not?matched.");}UserVO?vo?=?result.next();db.delete(vo);db.commit();}?catch?(Exception?e)?{db.rollback();}?finally?{//?關閉連接db.close();} }結論
通過本系列文章,db4o 的優勢已經體現得淋漓盡致,它的添加、更新、刪除是如此的簡單,正如 db4o 的口號那樣——“僅需一行代碼就能存儲復雜結構對象,極大的降低了開發時間和成本,提供高效的性能,無需 DBA 干預”。
如本文有不詳盡之處,大家可以參考官方的《用戶指南》,db4o 中文社區正在火熱成長!
參考資料
學習
db4o?官方網站?。
面向對象數據庫 db4o 之旅系列:查看此系列文章完整列表。
ODMG 官方網站:了解 ODMG 技術。
獲得產品和技術
下載 db4o 免費版。
轉載于:https://my.oschina.net/xionghui/blog/489727
總結
以上是生活随笔為你收集整理的面向对象的数据库db4o: 安装并使用db4o的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: matlab实现留一交叉验证,留出法和交
- 下一篇: [Android实例] 【eoeAndr