posts - 134,comments - 22,trackbacks - 0
          對(duì)象關(guān)系映射(Object Relational Mapping,簡(jiǎn)稱ORM)是一種為了解決面向?qū)ο笈c關(guān)系數(shù)據(jù)庫(kù)存在的互不匹配的現(xiàn)象的技術(shù)。簡(jiǎn)單的說,ORM是通過使用描述對(duì)象和數(shù)據(jù)庫(kù)之間映射的元數(shù)據(jù),將程序中的對(duì)象自動(dòng)持久化到關(guān)系數(shù)據(jù)庫(kù)中。本質(zhì)上就是將數(shù)據(jù)從一種形式轉(zhuǎn)換到另外一種形式。 這也同時(shí)暗示者額外的執(zhí)行開銷;然而,如果ORM作為一種中間件實(shí)現(xiàn),則會(huì)有很多機(jī)會(huì)做優(yōu)化,而這些在手寫的持久層并不存在。 更重要的是用于控制轉(zhuǎn)換的元數(shù)據(jù)需要提供和管理;但是同樣,這些花費(fèi)要比維護(hù)手寫的方案要少.

              對(duì)象-關(guān)系映射(Object/Relation Mapping,簡(jiǎn)稱ORM),是隨著面向?qū)ο蟮能浖_發(fā)方法發(fā)展而產(chǎn)生的,面向?qū)ο蟮拈_發(fā)方法是當(dāng)今企業(yè)級(jí)應(yīng)用開發(fā)環(huán)境中的主流開發(fā)方法,關(guān)系數(shù)據(jù)庫(kù)是企業(yè)級(jí)應(yīng)用環(huán)境中永久存放數(shù)據(jù)的主流數(shù)據(jù)存儲(chǔ)系統(tǒng)。對(duì)象和關(guān)系數(shù)據(jù)是業(yè)務(wù)實(shí)體的兩種表現(xiàn)形式,業(yè)務(wù)實(shí)體在內(nèi)存中表現(xiàn)為對(duì)象,在數(shù)據(jù)庫(kù)中表現(xiàn)為關(guān)系數(shù)據(jù)。內(nèi)存中的對(duì)象之間存在關(guān)聯(lián)和繼承關(guān)系,而在數(shù)據(jù)庫(kù)中,關(guān)系數(shù)據(jù)無(wú)法直接表達(dá)多對(duì)多關(guān)聯(lián)和繼承關(guān)系。因此,對(duì)象-關(guān)系映射(ORM)系統(tǒng)一般以中間件的形式存在,主要實(shí)現(xiàn)程序?qū)ο蟮疥P(guān)系數(shù)據(jù)庫(kù)數(shù)據(jù)的映射。

              面向?qū)ο笫菑能浖こ袒驹瓌t(如耦合、聚合、封裝)的基礎(chǔ)上發(fā)展起來的,而關(guān)系數(shù)據(jù)庫(kù)則是從數(shù)學(xué)理論發(fā)展而來的,兩套理論存在顯著的區(qū)別。為了解決這個(gè)不匹配的現(xiàn)象,對(duì)象關(guān)系映射技術(shù)應(yīng)運(yùn)而生。

              讓我們從O/R開始。字母O起源于"對(duì)象"(Object),而R則來自于"關(guān)系"(Relational)。幾乎所有的程序里面,都存在對(duì)象和關(guān)系數(shù)據(jù)庫(kù)。在業(yè)務(wù)邏輯層和用戶界面層中,我們是面向?qū)ο蟮摹.?dāng)對(duì)象信息發(fā)生變化的時(shí)候,我們需要把對(duì)象的信息保存在關(guān)系數(shù)據(jù)庫(kù)中。

              當(dāng)你開發(fā)一個(gè)應(yīng)用程序的時(shí)候(不使用O/R Mapping),你可能會(huì)寫不少數(shù)據(jù)訪問層的代碼,用來從數(shù)據(jù)庫(kù)保存,刪除,讀取對(duì)象信息,等等。你在DAL中寫了很多的方法來讀取對(duì)象數(shù)據(jù),改變狀態(tài)對(duì)象等等任務(wù)。而這些代碼寫起來總是重復(fù)的。

           

            如果打開你最近的程序,看看DAL代碼,你肯定會(huì)看到很多近似的通用的模式。我們以保存對(duì)象的方法為例,你傳入一個(gè)對(duì)象,為SqlCommand對(duì)象添加SqlParameter,把所有屬性和對(duì)象對(duì)應(yīng),設(shè)置SqlCommand的CommandText屬性為存儲(chǔ)過程,然后運(yùn)行SqlCommand。對(duì)于每個(gè)對(duì)象都要重復(fù)的寫這些代碼。

            除此之外,還有更好的辦法嗎?有,引入一個(gè)O/R Mapping。實(shí)質(zhì)上,一個(gè)O/R Mapping會(huì)為你生成DAL。與其自己寫DAL代碼,不如用O/R Mapping。你用O/R Mapping保存,刪除,讀取對(duì)象,O/R Mapping負(fù)責(zé)生成SQL,你只需要關(guān)心對(duì)象就好。

          一般的ORM包括以下四部分:

          u          一個(gè)對(duì)持久類對(duì)象進(jìn)行CRUD操作的API

          u          一個(gè)語(yǔ)言或API用來規(guī)定與類和類屬性相關(guān)的查詢;

          u          一個(gè)規(guī)定mapping metadata的工具;

          u          一種技術(shù)可以讓ORM的實(shí)現(xiàn)同事務(wù)對(duì)象一起進(jìn)行dirty checking, lazy association fetching以及其他的優(yōu)化操作。

          事例

          極致業(yè)務(wù)基礎(chǔ)平臺(tái)采用ORM技術(shù)實(shí)現(xiàn)數(shù)據(jù)的持久化,并提供了完整的實(shí)體定義工具,元數(shù)據(jù)管理機(jī)制,自動(dòng)生成關(guān)系數(shù)據(jù)庫(kù)表結(jié)構(gòu).

          平臺(tái)下載地址:

          http://www.jeez.com.cn/jbf

          posted on 2009-04-23 15:02 何克勤 閱讀(472) 評(píng)論(0)  編輯  收藏 所屬分類: 數(shù)據(jù)庫(kù)和SQL 其他
          主站蜘蛛池模板: 龙井市| 赤城县| 乳源| 秭归县| 南昌县| 谷城县| 获嘉县| 吉水县| 哈密市| 宜丰县| 满城县| 鄱阳县| 钦州市| 鄂伦春自治旗| 宁武县| 钟祥市| 九江县| 绥棱县| 天祝| 黄大仙区| 车致| 赫章县| 丰顺县| 樟树市| 河北区| 阿坝县| 木兰县| 航空| 东方市| 建德市| 嘉义县| 万源市| 阿尔山市| 乐至县| 育儿| 阜阳市| 江陵县| 托克逊县| 大丰市| 郯城县| 桂东县|