什么是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的使用及利弊》