一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

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

  在《基于T4的代碼生成方式》中,我對T4模板的組成結構、語法,以及T4引擎的工作原理進行了大體的介紹,并且編寫了一個T4模板實現了如何將一個XML轉變成C#代碼。為了讓由此需求的讀者對T4有更深的了解,我們通過T4來做一些更加實際的事情——SQL Generator。在這里,我們可以通過SQL Generator為某個數據表自動生成進行插入、修改和刪除的存儲過程。[文中源代碼從這里下載]

  一、代碼生成器的最終使用效果

  我們首先來看看通過直接適用我們基于T4的SQL生成模板達到的效果。右圖(點擊看大圖)是VS2010的Solution Explorer,在Script目錄下面,我定義了三個后綴名為.tt的T4模板。它們實際上是基于同一個數據表(T_PRODUCT)的三個存儲過程的生成創建的模板文件,其中P_PRODUCT_D.tt、P_PRODUCT_I.tt和P_PRODUCT_D.tt分別用于記錄的刪除、插入和修改。自動生成的擴展名為.sql的同名附屬文件就是相應的存儲過程。

  基于三種不同的數據操作(Insert、Update和Delete),我創建了3個重用的、與具體數據表無關的模板: InsertProcedureTemplate、UpdateProcedureTemplate和DeleteProcedureTemplate。這樣做的目的為為了實現最大的重用,如果我們需要為某個數據表創建相應的存儲過程的時候,我們可以直接使用它們傳入相應的數據表名就可以了。實際上,P_PRODUCT_D.tt、P_PRODUCT_I.tt和P_PRODUCT_D.tt這三個T4模板的結構很簡單,它們通過<#@include>指令將定義著相應ProcedureTemplate的T4模板文件包含進來。最終的存儲過程腳本通過調用ProcudureTempalte的Render方法生成。其中構造函數的參數表示的分別是連接字符串名稱(在配置文件中定義)和數據表的名稱。

<#@ template language="C#" hostspecific="True" #>
<#@ output extension="sql" #>
<#@ include file="T4Toolbox.tt" #>
<#@ include file="../Templates/DeleteProcedureTemplate.tt" #>
<#
    new DeleteProcedureTemplate("TestDb","T_PRODUCT").Render();
#>

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

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

主站蜘蛛池模板: 精品亚洲国产国拍 | a一区二区三区视频 | 色综合久久六月婷婷中文字幕 | 国产婷婷一区二区在线观看 | 亚洲国产网站 | 色女人综合网 | 国产1页| 色婷婷一区二区三区四区成人网 | 国产成人综合亚洲亚洲欧美 | 亚洲高清国产拍精品影院 | 色狠狠一区二区三区香蕉蜜桃 | 视频国产免费 | 91精品视频在线播放 | 婷婷在线网站 | 91精品国产91热久久久久福利 | 米奇777超碰欧美日韩亚洲 | 亚洲精品三区 | 午夜精品久视频在线观看 | 国产激情小视频 | 精品国产高清不卡毛片 | 欧美激情中文字幕一区二区 | 丁香视频在线观看播放 | 日本网络视频www色高清免费 | 精品欧美日韩一区二区三区 | 中文字幕一区二区在线视频 | 九一国产 | 国产成人精品一区二三区 | 综合久久久久久久综合网 | 亚洲综合15p| 四虎影视在线影院4hutv | 午夜爽爽性刺激一区二区视频 | 国产中文字幕在线视频 | 国产在线麻豆自在拍91精品 | 福利视频一区二区三区 | 牛牛热在线视频 | 国产精品毛片一区二区三区 | 精品欧美日韩一区二区三区 | 伊人精品视频在线观看 | 韩国欧洲一级毛片免费 | 97在线视频精品 | 日本精品1在线区 |