2021-03-10 分類: 網(wǎng)站建設
ORM(Object-relational mapping),中文翻譯為對象關(guān)系映射,是一種為了解決面向?qū)ο笈c關(guān)系數(shù)據(jù)庫存在的互不匹配的現(xiàn)象的技術(shù)。簡單的說,ORM是通過使用描述對象和數(shù)據(jù)庫之間映射的元數(shù)據(jù),將程序中的對象自動持久化到關(guān)系數(shù)據(jù)庫中。
在程序開發(fā)中,數(shù)據(jù)庫保存的表,字段與程序中的實體類之間是沒有關(guān)聯(lián)的,在實現(xiàn)持久化時就比較不方便。那么,到底如何實現(xiàn)持久化呢?一種簡單的方案是采用硬編碼方式,為每一種可能的數(shù)據(jù)庫訪問操作提供單獨的方法。這種方案存在以下不足:
ORM提供了實現(xiàn)持久化層的另一種模式,它采用映射元數(shù)據(jù)來描述對象關(guān)系的映射,使得ORM中間件能在任何一個應用的業(yè)務邏輯層和數(shù)據(jù)庫層之間充當橋梁
ORM的方法論基于三個核心原則:
本文以C#編程語言為例,在傳統(tǒng)的數(shù)據(jù)讀取操作中,我們以Ado.net的方式對數(shù)據(jù)庫進行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#實現(xiàn)的偽代碼:
Person p = repository.GetPerson(10);
String name = p.getFirstName();
上面的示例代碼表示我們可以從數(shù)據(jù)倉庫repository中獲取到一個實體對象,當然數(shù)據(jù)倉庫中可能包含其他的方法,你也可以定義自己的ORM實現(xiàn),比如:
Person p = Person.Get(10);
通常,在處理ORM映射和數(shù)據(jù)倉庫時會暴露一些過濾或者查詢方法,允許客戶端對數(shù)據(jù)集進行進一步的篩選等操作,比如代碼演示從數(shù)據(jù)庫中查詢ID=10的用戶:
Person p = Person.Get(Person.Properties.Id == 10);
與傳統(tǒng)的數(shù)據(jù)庫訪問技術(shù)相比,ORM有以下優(yōu)點:
從系統(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ù)庫應用上更有可能會被誤用,主要體現(xiàn)在對持久對象的提取和和數(shù)據(jù)的加工處理上,如果用上了ORM,程序員很有可能將全部的數(shù)據(jù)提取到內(nèi)存對象中,然后再進行過濾和加工處理,這樣就容易產(chǎn)生性能問題。
作為一名編程人員,在ORM使用的觀念上會有不同,具體取舍需根據(jù)具體的項目和場景。
名稱欄目:什么是ORM?為什么用ORM?淺析ORM的使用及利弊
當前網(wǎng)址:http://jinyejixie.com/news46/104946.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站設計、網(wǎng)站收錄、手機網(wǎng)站建設、網(wǎng)站設計、云服務器、建站公司
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容