数据库生成T4模版在代码生成中的应用心得
在本篇文章中,我們主要介紹數(shù)據(jù)庫(kù)生成的內(nèi)容,自我感覺(jué)有個(gè)不錯(cuò)的提議和大家分享下
????轉(zhuǎn)眼之間,我用T4模版已經(jīng)三年多的時(shí)間。三年來(lái),經(jīng)過(guò)幾個(gè)項(xiàng)目的磨合,在應(yīng)用上偶有心得,在這里把一些問(wèn)題一一羅列出來(lái)。
????
? ? ? ?2010年9月,我第一次接觸EntityFramework3.5,深深的被它類(lèi)powerdesigner感動(dòng),開(kāi)始琢磨它的應(yīng)用。當(dāng)時(shí)項(xiàng)目中,有位大拿,老琢磨EF、域模型以及MVC的搭配,對(duì)EF進(jìn)行擴(kuò)展等等。當(dāng)時(shí)沒(méi)有新項(xiàng)目,就做各種mode,挺好玩的。
? ? ? ?過(guò)了一年,2011年,做了一個(gè)很小的項(xiàng)目,只有7、8個(gè)對(duì)象,用EF的關(guān)系圖生成model,然后生成sql,生成數(shù)據(jù)庫(kù),開(kāi)始編碼等等,一個(gè)項(xiàng)目下來(lái),確實(shí)能夠增加不少工作量,性能還可以忍受,唯一的就是支持的數(shù)據(jù)庫(kù)太單一。
????
????過(guò)幾個(gè)月,2012年,又做一個(gè)大點(diǎn)的項(xiàng)目,喜劇發(fā)生了。計(jì)劃的不完善,mode老變,數(shù)據(jù)庫(kù)結(jié)構(gòu)也隨著變,需要改很多多少地方;于是就開(kāi)始查看各個(gè)大拿對(duì)EF的理解,花費(fèi)了點(diǎn)時(shí)間,什么數(shù)據(jù)庫(kù)優(yōu)先、model優(yōu)先、代碼優(yōu)先,都有很多例子,最后還是數(shù)據(jù)庫(kù)優(yōu)先才是我需要的。
????
????為什么選數(shù)據(jù)庫(kù)優(yōu)先呢?一般,我們做的系統(tǒng),都是應(yīng)用數(shù)據(jù)庫(kù)驅(qū)動(dòng),并且計(jì)劃的不完善數(shù)據(jù)庫(kù)還老變;我們手工改一個(gè)地方好呢還是每個(gè)地方都改,明顯只需要修改數(shù)據(jù)庫(kù)一個(gè)地方就能夠改好全部的地方是最理想的,于是在后來(lái)的全部項(xiàng)目中,我都應(yīng)用數(shù)據(jù)庫(kù)優(yōu)先。
每日一道理記不清有多少個(gè)夜晚,在我翻閱紙張的指間滑落;記不清有多少支蠟燭,在我的凝視中化為灰燼。逝者如斯,我時(shí)時(shí)刻刻會(huì)聽(tīng)見(jiàn)自己對(duì)生命承諾的余音,感到歲月的流轉(zhuǎn)在漸漸稀釋我的年少無(wú)知,我愿自己是一只上足了發(fā)條的時(shí)鐘,在晝夜不停的流轉(zhuǎn)中留下自己充實(shí)的每一刻。
????
????代碼優(yōu)先,在EF4.5出來(lái)后提的非常多,我以為僅僅是EF對(duì)性能的提升而做的一點(diǎn)點(diǎn)轉(zhuǎn)變,在真實(shí)的項(xiàng)目中,工作量有點(diǎn)困難。最后,還是會(huì)轉(zhuǎn)化為數(shù)據(jù)庫(kù)驅(qū)動(dòng),在用T4模版生成各個(gè)層次的代碼。
????
????我用的數(shù)據(jù)庫(kù)優(yōu)先,并非完全的應(yīng)用數(shù)據(jù)庫(kù)優(yōu)先,而僅僅是增加了一個(gè)層而已,把它最為一個(gè)對(duì)象的定義以及關(guān)系映射罷了,在項(xiàng)目中沒(méi)有現(xiàn)實(shí)的運(yùn)用。項(xiàng)目中的數(shù)據(jù)持久層,用傳統(tǒng)的sqlhelper還是框架(NHibernate、EF代碼優(yōu)先),都通過(guò)T4模版生成響應(yīng)格式的代碼;甚至model、service等,也通過(guò)T4模版進(jìn)行響應(yīng)的生成。
????
? ? ? ?我通過(guò)這類(lèi)數(shù)據(jù)庫(kù)優(yōu)先的模式,在后來(lái)的幾個(gè)C#、Java項(xiàng)目中,得到了很好的運(yùn)用,工作量大量的增加。
????
????在對(duì)T4模版的應(yīng)用上,始終有人提議用各種代碼生成器,初期,我們也用過(guò),有好的也有欠好的,可沒(méi)有一個(gè)能夠趕得上T4。別人的代碼生成器,要么去用新語(yǔ)言的寫(xiě)模版,要么需要修改代碼,才能生成需要的代碼,拘束太多;T4模版,多么的自在,基本沒(méi)有學(xué)習(xí)曲線,拿來(lái)就能夠應(yīng)用。
????
????當(dāng)然,現(xiàn)在的EF還有很多缺陷,我以為最大的缺陷是不能讀取數(shù)據(jù)庫(kù)字段的描述。等待微軟對(duì)它的修改。
文章結(jié)束給大家分享下程序員的一些笑話語(yǔ)錄: 喬布斯:怎么樣還是咱安全吧!黑客:你的瀏覽器支持國(guó)內(nèi)網(wǎng)銀嗎?蘋(píng)果可以玩國(guó)內(nèi)的網(wǎng)游嗎喬布斯:......不可以黑客:那我研究你的漏洞干嘛,我也需要買(mǎi)奶粉!
--------------------------------- 原創(chuàng)文章 By
數(shù)據(jù)庫(kù)和生成
---------------------------------
總結(jié)
以上是生活随笔為你收集整理的数据库生成T4模版在代码生成中的应用心得的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: JAVA顺序表的简单实现
- 下一篇: Oracle 11g Release 2