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

什么是ORM

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

為什么用ORM

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

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

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

ORM的方法論基于三個核心原則:

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

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

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ù)倉庫repository中獲取到一個實(shí)體對象,當(dāng)然數(shù)據(jù)倉庫中可能包含其他的方法,你也可以定義自己的ORM實(shí)現(xiàn),比如:

Person p = Person.Get(10);

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

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

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

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

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

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

缺點(diǎn)

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

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

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

總結(jié)

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

本文同步發(fā)表至 圖享網(wǎng)什么是ORM?為什么用ORM?淺析ORM的使用及利弊

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容