| 什么是ORM?為什么用ORM?安徽ibm服務(wù)器租用 |
| 聯(lián)系人:盛網(wǎng)科技 (先生) | 手機(jī):13924367540 |
|
電話: |
傳真: |
| 郵箱:2191734315@qq.com | 地址:廣東省東莞市莞城街道匯峰路1號(hào)匯峰中心B區(qū)501單元 |
|
什么是ORM ORM(Object-relational mapping),中文翻譯為對(duì)象關(guān)系映射,是一種為了解決面向?qū)ο笈c關(guān)系數(shù)據(jù)庫(kù)存在的互不匹配的現(xiàn)象的技術(shù)。簡(jiǎn)單的說(shuō),ORM是通過使用描述對(duì)象和數(shù)據(jù)庫(kù)之間映射的元數(shù)據(jù),將程序中的對(duì)象自動(dòng)持久化到關(guān)系數(shù)據(jù)庫(kù)中。 為什么用ORM 在程序開發(fā)中,數(shù)據(jù)庫(kù)保存的表,字段與程序中的實(shí)體類之間是沒有關(guān)聯(lián)的,在實(shí)現(xiàn)持久化時(shí)就比較不方便。那么,到底如何實(shí)現(xiàn)持久化呢?一種簡(jiǎn)單的方案是采用硬編碼方式,為每一種可能的數(shù)據(jù)庫(kù)訪問操作提供單獨(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ì)暴露一些過濾或者查詢方法,允許客戶端對(duì)數(shù)據(jù)集進(jìn)行進(jìn)一步的篩選等操作,比如代碼演示從數(shù)據(jù)庫(kù)中查詢ID=10的用戶: Person p = Person.Get(Person.Properties.Id == 10); 盛網(wǎng)科技http://www.33ol.com/,服務(wù)器租用/托管,高性能,高配置,高防護(hù),高獨(dú)享7x24小時(shí)售后服務(wù),定制屬于你的專屬服務(wù)器。QQ:724015997企業(yè)Q:4000900901電話:13924367540 |
| 版權(quán)聲明:以上所展示的信息由會(huì)員自行提供,內(nèi)容的真實(shí)性、準(zhǔn)確性和合法性由發(fā)布會(huì)員負(fù)責(zé)。機(jī)電之家對(duì)此不承擔(dān)任何責(zé)任。 友情提醒:為規(guī)避購(gòu)買風(fēng)險(xiǎn),建議您在購(gòu)買相關(guān)產(chǎn)品前務(wù)必確認(rèn)供應(yīng)商資質(zhì)及產(chǎn)品質(zhì)量。 |
機(jī)電之家網(wǎng) - 機(jī)電行業(yè)權(quán)威網(wǎng)絡(luò)宣傳媒體
關(guān)于我們 | 聯(lián)系我們 | 廣告合作 | 付款方式 | 使用幫助 | 會(huì)員助手 | 免費(fèi)鏈接Copyright 2025 jdzj.com All Rights Reserved??技術(shù)支持:機(jī)電之家 服務(wù)熱線:0571-87774297
網(wǎng)站經(jīng)營(yíng)許可證:浙B2-20080178