面向對象是從
讓我們從O/R開始。字母O起源于"對象"(Object),而R則來自于"關系"(Relational)。幾乎所有的程序里面,都存在對象和關系數據庫。在業務邏輯層和
當你開發一個應用程序的時候(不使用O/R Mapping),你可能會寫不少數據訪問層的代碼,用來從數據庫保存,刪除,讀取對象信息,等等。你在DAL中寫了很多的方法來讀取對象數據,改變狀態對象等等任務。而這些代碼寫起來總是重復的。
如果打開你最近的程序,看看DAL代碼,你肯定會看到很多近似的通用的
除此之外,還有更好的辦法嗎?有,引入一個O/R Mapping。實質上,一個O/R Mapping會為你生成DAL。與其自己寫DAL代碼,不如用O/R Mapping。你用O/R Mapping保存,刪除,讀取對象,O/R Mapping負責生成
對象關系映射成功運用在不同的面向對象持久層產品中,如:Torque,OJB,Hibernate,TopLink,
一般的ORM包括以下四部分:
一個對持久類對象進行CRUD操作的
一個語言或API用來規定與類和類屬性相關的查詢;
一個規定mapping metadata的工具;
一種技術可以讓ORM的實現同事務對象一起進行dirty checking, lazy association fetching以及其他的優化操作。
目前眾多廠商和
Apache OJB (http://
Cayenne (http://objectstyle.org/cayenne/)
Jaxor (http://jaxor.sourceforge.net)
Hibernate (http://www.hibernate.org)
iBatis (http://www.ibatis.com)
jRelationalFramework (http://ijf.sourceforge.net)
mirage (http://itor.cq2.org/en/oss/mirage/toon)
SMYLE (http://www.drjava.de/smyle)
TopLink (http://otn.
其中 TopLink 是 Oracle 的商業產品,其他均為開源項目。
其中 Hibernate 的輕量級 ORM 模型逐步確立了在 Java ORM
從《公共倉庫元模型:開發指南》一書第8章CWM元倉庫中摘錄出來的內容,實現了公共倉庫元模型(CWM)的
基本情況:公共倉庫元模型(CWM)是對象管理組織(OMG)的一種和
采用方法:將UML模型中的各種元素通過轉換,保存為數據庫模式。由于CWM是一種元模型,因此模型的實例也是一種模型,將這種實例以數據庫數據的形式保存。使用數據庫中比較成熟的存儲過程技術提高開發和執行效率。
1.1簡單數據類型模式:建立UML和關系型數據庫中簡單數據類型的映射表以指導映射。
1.2枚舉數據類型模式:每種枚舉類型對應一個表,只有一個列(_EnumLiteral)表示枚舉值。
1.3基于類的數據類型模式:使用外鍵約束,將基礎列與基于類的類型實例相關聯。
每個類對應一個表。單值屬性、多值屬性、繼承關系可以用下述方法映射,而引用屬性將在關聯映射模式中提到。
2.1單值屬性模式:是cardinality的上界為1的屬性,映射到類所對應的表的列上。若其下界也為1(必須有的屬性),列屬性為NOT NULL。
2.2多值屬性模式:每個多值屬性映射成一個獨立的表,使用外鍵連接到類所對應的表上。
2.3繼承模式:每加入一個類的實例時,根據其繼承關系自頂向下生成每個類的對象,這些對象具有相同的ID(根對象對應記錄的主鍵)。刪除對象實例時,自底向上刪除數據。遇到從中間刪的情況怎么辦?多重繼承怎么處理?(金龍飛)
3.1一對一關聯模式:在關聯兩端各加一列。
3.2一對多關聯模式:和3.1一樣。如果多這端是有序的,還需加入一列表示序號。
3.3多對多關聯模式:將關聯單獨作一個表。
3.4組合關聯模式:注意級聯式刪除。
3.5反演關聯模式:關聯兩端指向相關的類型,和普通關聯一樣。
3.6成對關聯模式:關聯記錄兩個類間的關系,用交集類表示關聯,表示成一個單獨的表,每個關聯對應一個表,用外鍵表示它們間的關系。
3.7關聯上的OCL需要分析成對應的存儲過程代碼。
3.8保證關聯的cardinality也需要分析成對應的存儲過程代碼。
在UML中不存在的MOF特征,指屬性是聲明為引用類型的實例。用存儲過程實現。