什么是ORM?為什么用ORM?淺析ORM的使用及利弊

2021-03-10    分類: 網(wǎng)站建設(shè)

什么是ORM

ORM(Object-relational mapping),中文翻譯為對(duì)象關(guān)系映射,是一種為了解決面向?qū)ο笈c關(guān)系數(shù)據(jù)庫(kù)存在的互不匹配的現(xiàn)象的技術(shù)。簡(jiǎn)單的說(shuō),ORM是通過(guò)使用描述對(duì)象和數(shù)據(jù)庫(kù)之間映射的元數(shù)據(jù),將程序中的對(duì)象自動(dòng)持久化到關(guān)系數(shù)據(jù)庫(kù)中。

ORM

為什么用ORM

在程序開發(fā)中,數(shù)據(jù)庫(kù)保存的表,字段與程序中的實(shí)體類之間是沒(méi)有關(guān)聯(lián)的,在實(shí)現(xiàn)持久化時(shí)就比較不方便。那么,到底如何實(shí)現(xiàn)持久化呢?一種簡(jiǎn)單的方案是采用硬編碼方式,為每一種可能的數(shù)據(jù)庫(kù)訪問(wèn)操作提供單獨(dú)的方法。這種方案存在以下不足:

  • 1.持久化層缺乏彈性。一旦出現(xiàn)業(yè)務(wù)需求的變更,就必須修改持久化層的接口
  • 2.持久化層同時(shí)與域模型與關(guān)系數(shù)據(jù)庫(kù)模型綁定,不管域模型還是關(guān)系數(shù)據(jù)庫(kù)模型發(fā)生變化,毒藥修改持久化曾的相關(guān)程序代碼,增加了軟件的維護(hù)難度

ORM提供了實(shí)現(xiàn)持久化層的另一種模式,它采用映射元數(shù)據(jù)來(lái)描述對(duì)象關(guān)系的映射,使得ORM中間件能在任何一個(gè)應(yīng)用的業(yè)務(wù)邏輯層和數(shù)據(jù)庫(kù)層之間充當(dāng)橋梁

ORM的方法論基于三個(gè)核心原則:

  • 簡(jiǎn)單:以最基本的形式建模數(shù)據(jù)
  • 傳達(dá)性:數(shù)據(jù)庫(kù)結(jié)構(gòu)被任何人都能理解的語(yǔ)言文檔化
  • 精確性:基于數(shù)據(jù)模型創(chuàng)建正確標(biāo)準(zhǔn)化了的結(jié)構(gòu)

本文以C#編程語(yǔ)言為例,在傳統(tǒng)的數(shù)據(jù)讀取操作中,我們以Ado.net的方式對(duì)數(shù)據(jù)庫(kù)進(jìn)行CRUD操作,使用的基本都是SQL硬編碼,比如有以下數(shù)據(jù)庫(kù)查詢操作:

String sql = "SELECT ... FROM persons WHERE id = 10";
DbCommand cmd = new DbCommand(connection, sql);
Result res = cmd.Execute();
String name = res[0]["FIRST_NAME"];

使用了ORM映射的C#實(shí)現(xiàn)的偽代碼:

Person p = repository.GetPerson(10);
String name = p.getFirstName();

上面的示例代碼表示我們可以從數(shù)據(jù)倉(cāng)庫(kù)repository中獲取到一個(gè)實(shí)體對(duì)象,當(dāng)然數(shù)據(jù)倉(cāng)庫(kù)中可能包含其他的方法,你也可以定義自己的ORM實(shí)現(xiàn),比如:

Person p = Person.Get(10);

通常,在處理ORM映射和數(shù)據(jù)倉(cāng)庫(kù)時(shí)會(huì)暴露一些過(guò)濾或者查詢方法,允許客戶端對(duì)數(shù)據(jù)集進(jìn)行進(jìn)一步的篩選等操作,比如代碼演示從數(shù)據(jù)庫(kù)中查詢ID=10的用戶:

Person p = Person.Get(Person.Properties.Id == 10);

優(yōu)/缺點(diǎn)

優(yōu)點(diǎn)

與傳統(tǒng)的數(shù)據(jù)庫(kù)訪問(wèn)技術(shù)相比,ORM有以下優(yōu)點(diǎn):

  • 開發(fā)效率更高
  • 數(shù)據(jù)訪問(wèn)更抽象、輕便
  • 支持面向?qū)ο蠓庋b

缺點(diǎn)

  • 降低程序的執(zhí)行效率
  • 思維固定化

從系統(tǒng)結(jié)構(gòu)上來(lái)看,采用ORM的系統(tǒng)一般都是多層系統(tǒng),系統(tǒng)的層次多了,效率就會(huì)降低。ORM是一種完全的面向?qū)ο蟮淖龇?,而面向?qū)ο蟮淖龇ㄒ矔?huì)對(duì)性能產(chǎn)生一定的影響。

在我們開發(fā)系統(tǒng)時(shí),一般都有性能問(wèn)題。性能問(wèn)題主要產(chǎn)生在算法不正確和與數(shù)據(jù)庫(kù)不正確的使用上。ORM所生成的代碼一般不太可能寫出很高效的算法,在數(shù)據(jù)庫(kù)應(yīng)用上更有可能會(huì)被誤用,主要體現(xiàn)在對(duì)持久對(duì)象的提取和和數(shù)據(jù)的加工處理上,如果用上了ORM,程序員很有可能將全部的數(shù)據(jù)提取到內(nèi)存對(duì)象中,然后再進(jìn)行過(guò)濾和加工處理,這樣就容易產(chǎn)生性能問(wèn)題。

總結(jié)

作為一名編程人員,在ORM使用的觀念上會(huì)有不同,具體取舍需根據(jù)具體的項(xiàng)目和場(chǎng)景。

當(dāng)前題目:什么是ORM?為什么用ORM?淺析ORM的使用及利弊
URL標(biāo)題:http://www.bm7419.com/news/104946.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、企業(yè)網(wǎng)站制作、虛擬主機(jī)、網(wǎng)站維護(hù)網(wǎng)站策劃、自適應(yīng)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都定制網(wǎng)站建設(shè)