2021-03-10 分類: 網(wǎng)站建設(shè)
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ù)中。
在程序開(kāi)發(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ú)的方法。這種方案存在以下不足:
ORM提供了實(shí)現(xiàn)持久化層的另一種模式,它采用映射元數(shù)據(jù)來(lái)描述對(duì)象關(guān)系的映射,使得ORM中間件能在任何一個(gè)應(yīng)用的業(yè)務(wù)邏輯層和數(shù)據(jù)庫(kù)層之間充當(dāng)橋梁
ORM的方法論基于三個(gè)核心原則:
本文以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);
與傳統(tǒng)的數(shù)據(jù)庫(kù)訪問(wèn)技術(shù)相比,ORM有以下優(yōu)點(diǎn):
從系統(tǒng)結(jié)構(gòu)上來(lái)看,采用ORM的系統(tǒng)一般都是多層系統(tǒng),系統(tǒng)的層次多了,效率就會(huì)降低。ORM是一種完全的面向?qū)ο蟮淖龇?,而面向?qū)ο蟮淖龇ㄒ矔?huì)對(duì)性能產(chǎn)生一定的影響。
在我們開(kāi)發(fā)系統(tǒng)時(shí),一般都有性能問(wèn)題。性能問(wèn)題主要產(chǎn)生在算法不正確和與數(shù)據(jù)庫(kù)不正確的使用上。ORM所生成的代碼一般不太可能寫(xiě)出很高效的算法,在數(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)題。
作為一名編程人員,在ORM使用的觀念上會(huì)有不同,具體取舍需根據(jù)具體的項(xiàng)目和場(chǎng)景。
當(dāng)前題目:什么是ORM?為什么用ORM?淺析ORM的使用及利弊
URL標(biāo)題:http://jinyejixie.com/news/104946.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開(kāi)發(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)
猜你還喜歡下面的內(nèi)容