亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Nhibernate分析之華山論劍篇

系統(tǒng) 2301 0

原來一直使用代碼生成,包括CodeSmith和天平兄的CodeMatic。最近打算系統(tǒng)學習一下Nhibernate,經(jīng)過簡單的一點探索,發(fā)現(xiàn)ORM和代碼生成真是個有千秋。本文側(cè)重比較一下ORM和代碼生成二者的優(yōu)缺點,讓二者華山一比高下,目的為去偽存真,使二者能夠相輔相成。從而更好的提高開發(fā)效率。
本文從下面三個層面對ORM(以NHibernate為首發(fā)的O陣營) 和代碼生成(以CodeMatic為首發(fā)的C陣營)進行比較:
1)針對數(shù)據(jù)庫二者的架構(gòu)層次上的異同
2) 針對應用程序二者在使用和配置上的異同
3) 針對業(yè)務邏輯二者在對變化和復雜度上支持度的異同。
下面就具體針對這三個層面做一下具體分析,這些分析都來源于自己開發(fā)中的一些經(jīng)驗和心得,有些是正確的,有些也存在這樣那樣的問題。寫出來,希望的也只是能拋磚引玉,得到更多朋友,兄弟的幫助和支持。
1) 針對數(shù)據(jù)庫二者在架構(gòu)層次上異同
首先看一下下面這張圖:
Nhibernate分析之華山論劍篇
ORM針對數(shù)據(jù)庫是由上而下的關系,也就是說ORM并不依賴于數(shù)據(jù)庫。他可以完全從關系數(shù)據(jù)庫中將程序員解放出來,需要程序員小心呵護的是傳遞給nhibernate的persistent object。這看起來更加OO,而代碼生成恰恰相反,代碼生成依賴于關系數(shù)據(jù)庫。它總結(jié)數(shù)據(jù)庫操作的一些共性,將本來需要程序員手寫的代碼自動生成出來。從OO的角度來說,代碼生成的過程并不體現(xiàn)OO思想,但根據(jù)模版或者軟件作者的一些邏輯。生成出來的代碼卻可能具有很好的OO思想。針對數(shù)據(jù)庫來說,ORM是自頂向下的,代碼生成則是自下而上。二者方向恰好相反。
2)針對應用程序二者在使用和配置上的異同
nhinernate的使用需要在原有系統(tǒng)上添加對nhibernate.dll和其他一些相關的dll的引用,而代碼生成則不然,代碼生成是在另外的一個軟件中,通過指定數(shù)據(jù)庫來生成用于操作數(shù)據(jù)庫的文件,將這些文件添加到項目中的時候才可以正常使用。nhibernate最讓人頭疼的就是配置和映射文件的編寫。而代碼生成,如果需要完成復雜的邏輯和自定義的業(yè)務,需要編寫CodeSmith等軟件的模版,這些模版的編寫也不是一件簡單的事情。從使用和配置上看,二者的異同在于

使用方法 引用方法 配置文件
nhibernate 系統(tǒng)內(nèi) 需要添加相關引用 需要編寫大量的配置和映射文件。
codematic 系統(tǒng)外 不需要添加引用 業(yè)務簡單時不需要配置,復雜時需要編寫自定義模版
3)針對業(yè)務邏輯二者在對變化和復雜度上支持度的異同
假如原有一個User表,這個表已經(jīng)運行了一段時間。但目前需要在User表里面添加一個可為null的字段:BirthDay,二者對此需求的響應各自是應該是怎么樣的呢?
數(shù)據(jù)庫改動 配置改動 代碼更改
nhibernate 無需 需要映射文件中添加對BirthDay的映射 更改User類,添加屬性BirthDay
codematic 需要在User表里面添加一個BirthDay字段 不需要更改 最佳使用狀態(tài)下需要從數(shù)據(jù)層到業(yè)務邏輯層重新生成代碼,如果以前有改動,則需要手動添加BirthDay向伽相關代碼
針對于單表操作,二者都比較簡單,但是當業(yè)務變得復雜的時候,二者在表現(xiàn)力如何呢?比如現(xiàn)在有這樣一種應用環(huán)境,計算和維護職員和工資,需求:1)列出所有職員 2)列出某個職員的某月的工資信息 3) 統(tǒng)計某個員工在第2個季度的總工資。4)計算上半年公司支付給員工的總工資。其中包括已離職人員的工資。
在這樣一種應用環(huán)境下,分別討論二者如何應付
數(shù)據(jù)表 業(yè)務對象 配置文件 業(yè)務對象的使用
nhibernate 無需創(chuàng)建 手動編寫User,Salary業(yè)務對象。 需要編寫配置文件,標示業(yè)務對象的主從關系 在二者差生圍度和關聯(lián)時,內(nèi)置支持
codematic 需要創(chuàng)建User和Salary表,并指定主從 不需 不需 產(chǎn)生關聯(lián)和圍度時,需要手工更改數(shù)據(jù)底層和上層業(yè)務代碼
總結(jié),ORM和代碼生成二者各有各自的好處,但綜合考慮ORM更符合OO的口味,而代碼生成則比較靈活,可以應用到除了數(shù)據(jù)庫操作的其他方面。比如生成nhibernate需要的映射文件等。加上原有的URM和數(shù)據(jù)建模,幾者共用,開發(fā)效率一定會有較大的提高。

Nhibernate分析之華山論劍篇


更多文章、技術(shù)交流、商務合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦?。。?/p>

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 国产成人在线免费视频 | 九色国产在视频线精品视频 | 成人三级做爰在线观看男女 | 欧美综合图片区 | 久久精品国产亚洲精品2020 | 91热久久免费频精品动漫99 | 国产欧美一区二区精品仙草咪 | 伊人久久成人 | 国产乱仑| 青青青爽在线视频观看大全 | 精品久久久久久久久久久 | 国产中文字幕在线 | 骚碰97 | 国产一级毛片网站 | 国产a国产 | 在线观看国产视频 | 国产精品a区 | 久久只有这里有精品 | swag国产精品一区二区 | 久久久久美女 | 湿湿影院在线观看 | 亚洲国产第一区 | 亚洲欧美日韩国产一区二区精品 | 狠狠久久久久久亚洲综合网 | 99热精品成人免费观看 | 伊人第一页 | 四虎永久影院永久影库 | 久久久久久国产精品免费 | 国产亚洲综合一区在线 | 亚洲第一a | 亚洲一区二区三区四区 | 中文字幕日韩欧美一区二区三区 | 久操视频免费观看 | 欧美一级片免费 | 国内精品久久影院 | 九九热视频在线免费观看 | 日日摸夜夜添夜夜添欧美毛片 | 婷婷国产成人久久精品激情 | 亚洲精品视频在线播放 | 午夜视频福利 | 欧美不卡精品中文字幕日韩 |