天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

創建代碼生成器可以很簡單:如何通過T4模板生成代碼?[下篇]

  在《上篇》中我們通過T4模板為我們指定的數據表成功生成了我們需要的用于添加、修改和刪除操作的存儲過程。但是這是一種基于單個文件的解決方案,即我們必須為每一個生成的存儲過程建立一個模板。如果我們提供一種基于多文件的代碼生成方式,將會為編程人員帶來極大的便利。借助于T4 ToolBox這個開源工具箱,多文件的SQL Generator的實現變得異常簡單。

  一、多文件代碼生成器會帶來多大的便利?

  我們先來直觀的感受一下較之《上篇》提供的單一文件的代碼生成器,基于多文件的代碼生成解決方案會為開發人員帶來多大的便利。 同樣對于《上篇》創建的數據表T_PRODUCT,之前我們為了生成三個不同的存儲過程,我們不得已需要創建3個不同的T4模板文件。實際上我們更需要的方式只需要創建一個T4模板,讓我們的SQL Generator自動為我們生成3個包含相應存儲過程的.sql附屬文件,如左圖所示(點擊看大圖)。

  有的時候,基于單個數據表的存儲過程生成方式我們依然覺得不方便。如果我們能夠在T4模板文件中指定的數據表的列表,讓我們的SQL Generator為列表的每一個數據表都生成CUD三個存儲過程,這樣的方式更加具有吸引力。如右圖所示(點擊看大圖),一個訂單模塊包含兩個具有主子關系的兩張表(T_ORDER和T_ORDER_DETAIL),現在我們在一個T4模板中指定這兩個表明,通過SQL Generator可以幫助我們生成6個包含存儲過程的.sql附屬文件。

  甚至有的時候我們連數據表列表都無需指定,讓SQL Generator為所有的表都生成相應的存儲過程。我的例子中沒有提供這樣的功能,但是實現自來不會存在任何問題。

  二、創建自定義的Generator

  在《上篇》中我創建了一個抽象的ProcedureTemplate類,以及三個基于生成CUD存儲過程的具體ProcedureTemplate: InsertProcedureTemplate、UpdateProcedureTemplate和DeleteProcedureTemplate。它們都將直接服務于我們今天將要提供的基于多文件的SQL Generator。

  在《上篇》中,這四個Template分別定義在4個不同的TT文件中,3個具體的ProcedureTemplate通過<#@include>指令將抽象ProcedureTemplate模板文件包含過來。由于我們將要創建的T4模板將會使用到這四個類,如果我們用四個<#@include>指令將四個TT文件包含過來,由于T4引擎將會導致對ProcedureTemplate的4次包含,最好將會導致變異問題。個人覺得這應該算是T4引擎解析包含關系的一個局限性,為了解決這個問題我們不得不抽象的ProcedureTemplate和三個具體的ProcedureTemplate都合并成一個TT文件。

  T4 ToolBox為類庫中為了提供了一個抽象的T4Toolbox.Generator類用于實現多文件的代碼生成。為此我們創建一個TT模板文件,定義了如下一個繼承自該類的ProcedureGenerator。ProcedureGenerator的核心是通過屬性Templates定義的類型為IEnumerable<ProcedureTemplate>的ProcedureTemplate列表,這個列表在存儲過程中進行初始化。而對于ProcedureGenerator的構造函數,處理定義了一個表示數據庫連接字符串的databaseName的參數外,要以數組參數的形式指定了生成的存儲過程基于的數據表名的列表。

<#@ import namespace="System.Collections.Generic" #>
<#@ include file="ProcedureTemplate.tt" #>
<#@ include file="T4Toolbox.tt" #>
<#+
public class ProcedureGenerator : Generator
{
public IEnumerable<ProcedureTemplate> Templates{get; private set;}

public ProcedureGenerator(string databaseName, params string[] tableNames)
{
if(null == tableNames || tableNames.Length == 0)
{
throw new ArgumentNullException("tableNames");
}

this.Templates = InitlizeTemplates(databaseName,tableNames);
}

private IEnumerable<ProcedureTemplate> InitlizeTemplates(string databaseName, string[] tableNames)
{
foreach(string tableName in tableNames)
{
yield return new InsertProcedureTemplate(databaseName, tableName);
yield return new UpdateProcedureTemplate(databaseName, tableName);
yield return new DeleteProcedureTemplate(databaseName, tableName);
}
}

protected override void RunCore()
{
foreach(ProcedureTemplate tempalte in this.Templates)
{
tempalte.RenderToFile(tempalte.GetProcedureName()
+ ".sql");
}
}
}
#
>

NET技術創建代碼生成器可以很簡單:如何通過T4模板生成代碼?[下篇],轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲欧美自拍清纯中文字幕 | 一本色道久久综合一区 | 色翁荡息又大又硬又粗又爽电影 | 久久中文字幕人妻AV熟女 | 免费成年人在线视频 | 69国产精品成人无码视频 | 久久久擼擼擼麻豆 | 欧美精品色视频 | 美女教师朝桐光在线播放 | 无码乱人伦一区二区亚洲 | 国产中文字幕乱码一区 | 国产老师开裆丝袜喷水漫画 | 激情综合色| 良家人妻无码专区九色颜射 | 337p啪啪人体大胆 | 亚洲 日本 欧美 中文字幕 | 白丝萝莉喷水 | 国产午夜不卡在线观看视频666 | 亚洲高清国产拍精品动图 | 18禁国产精品久久久久久麻豆 | 欧美高清vivoesond在线播放 | GOGOGO高清在线播放韩国 | 一个人免费视频在线观看高清版 | 国产精品亚洲欧美一区麻豆 | 51国产午夜精品免费视频 | 国产AV亚洲国产AV麻豆 | 中文字幕网站在线观看 | 视频一区亚洲中文字幕 | 久久99re6热在线播放 | 日韩视频中文在线一区 | 微拍秒拍99福利精品小视频 | 护士WC女子撒尿 | 69久久国产精品热88人妻 | 国产精品成久久久久三级四虎 | 国产激情视频在线播放 | 日本美女毛茸茸 | 亚洲精品天堂无码中文字幕影院 | 精品久久久久中文字幕 | 亚洲国产在线精品国自产拍五月 | 午夜伦理伦理片在线观 | 久久精品亚洲热综合一本奇米 |