成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一款基于模板的代碼生成工具Template Studio

開發(fā) 后端
Template Studio是一款基于模板的優(yōu)秀代碼生成工具,本文作為入門教程,給大家比較各自的優(yōu)勢(shì)和不足。

  LLBL Gen作為一個(gè)優(yōu)秀的ORM代碼生成工具,可以基于模板快速生成應(yīng)用程序代碼。可能你也會(huì)推薦T4,Code Smith等模板生成器,但是先別急,先看看這篇文章作為入門教程,再來(lái)比較各自的優(yōu)勢(shì)和不足。

  以第三方的模板Provide common SQL Functions for Microsoft SQL Server為例子,來(lái)講解模板生成的步驟。

  設(shè)計(jì)模板

  打開Template Studio,選擇TemplateBindings Viewer,點(diǎn)擊New按鈕,新增加一個(gè)模板TemplateBinding文件

這是方便LLBL Gen工作而進(jìn)行的設(shè)定,有幾個(gè)關(guān)鍵項(xiàng)

  For database是模板支持的數(shù)據(jù)庫(kù)類型,只可以選擇一種數(shù)據(jù)庫(kù)類型;選擇Platform表示生成的代碼可以支持的.NET Framework版本,這將影響到可以生成的Visual Studio的sln和cs/vb.proj文件的版本。Target language選擇C#,以表明生成C#代碼;Logic language表示書寫模板用的語(yǔ)言是TDL語(yǔ)法。

  請(qǐng)?jiān)赥emplateID-Filename bindings中綁定模板標(biāo)識(shí)和對(duì)應(yīng)的模板文件名稱。

  TemplateBinding是一個(gè)XML格式的配置文件,其內(nèi)容如下

  1.   <?xml version="1.0"?>  
  2.   <templateBindings xmlns="http://sd/llblgen/pro/templateBindingsDefinition.xsd"name="WB.TemplateBindings.SqlServerSpecific.NET20" 
  3. description ="Template bindings for the templates which are specific for SqlServer based databases (7/2000/2005/CE). For .NET 2.0 based platforms" 
  4. databaseDriverID="2D18D138-1DD2-467E-86CC-4838250611AE" precedenceLevel="10">  description ="Template bindings for the templates which are specific for SqlServer based databases (7/2000/2005/CE). For .NET 2.0 based platforms" 
  5.   databaseDriverID="2D18D138-1DD2-467E-86CC-4838250611AE" precedenceLevel="10">  
  6.   <supportedPlatforms>  
  7.   <platform name=".NET 2.0"/>  
  8.   <platform name="CF.NET 2.0"/>  
  9.   </supportedPlatforms>  
  10.   <language name="C#">  
  11.   <!-- DB Specific template bindings -->  
  12.   <templateBinding emplateID="WB.SQLSystemFunctionsTemplate" filename="SqlServerSpecificNet2.xC#WB.SQLSystemFunctions.template" />  
  13.   </language>  
  14.   </templateBindings> 

  這是代碼批處理生成的思想。比如我有五個(gè)模板,現(xiàn)在給這五個(gè)模板添加一個(gè)配置文件,引用到這五個(gè)模板,然后

  只需要啟動(dòng)配置文件,生成代碼時(shí),會(huì)自動(dòng)傳遞參數(shù)到這五個(gè)模板中,批次生成代碼。

  選中WB.SQLSystemFunctionsTemplate,用快捷鍵CTRL+E,編輯它對(duì)應(yīng)的模板文件WB.SQLSystemFunctions.template。

LogicTDL語(yǔ)法和ASP.NET很相似,但是使用<[和]>表示模板中使用到的變量。

  在《LLBLGenPro2.6SDKDocumentation》文檔的Template Sets - Template Definition Language (TDL)節(jié),提到了<[RootNamespace]>的含義,原文是Will be replaced by the specified Root namespace in the generator configuration screen,理解為取生成代碼時(shí)輸入的命名空間變量。

  啟動(dòng)LLBL Gen,配置生成參數(shù)

  F7調(diào)出代碼生成界面,切換到Task queue to execute,Add Tasks添加一個(gè)新任務(wù),選擇類型為SD.Tasks.Base.ConsumeTDLTemplate, 這個(gè)任務(wù)將會(huì)用于編譯第一節(jié)寫的模板,并生成C#代碼。

  修改參數(shù) filenameFormat=SqlFunctionCalls.[extension],templateID=WB.SQLSystemFunctionsTemplate

  這其實(shí)是在配置代碼生成的preset文件,文件內(nèi)容如下

  1.   <?xml version="1.0" encoding="utf-8"?>  
  2.   <preset name="SQL Functions" lastModifiedOn="2011-08-30T22:40:50.3165235+08:00" createdBy="Northwind" isSealed="false" xmlns="http://sd/llblgen/pro/presetElementDefinitions.xsd">  
  3.   <supportedPlatforms>  
  4.   <platform name=".NET 2.0" />  
  5.   </supportedPlatforms>  
  6.   <supportedTemplateGroups>  
  7.   <templateGroup name="Adapter" />  
  8.  </supportedTemplateGroups>  
  9.   <taskPresets>  
  10.   <taskPreset name="SD.Tasks.Base.ConsumeTDLTemplate">  
  11.   <parameters>  
  12.   <parameter name="destinationFolder" value="" />  
  13.   <parameter name="filenameFormat" value="SqlFunctionCalls.[extension]" />  
  14.   <parameter name="templateID" value="WB.SQLSystemFunctionsTemplate" />  
  15.   </parameters>  
  16.   </taskPreset>  
  17.   </taskPresets>  
  18.   </preset> 

  到此,已經(jīng)配置完畢,點(diǎn)擊Start generator按鈕,生成代碼。

  模板文件的分析

  再來(lái)看一下模板的作用,這個(gè)模板的作用是把內(nèi)置SQL Server系統(tǒng)中的date和string函數(shù),轉(zhuǎn)化為C#代碼。

  如果要調(diào)用SQL Server中的YEAR函數(shù),可能要寫這樣的方法

  1.   private int GetSQLServerYear()  
  2.   {  
  3.   ResultsetFields fields = new ResultsetFields(1);  
  4.   fields.DefineField(new EntityField("AFld"new DbFunctionCall("YEAR"new object[] { DateTime.Today })), 0);  
  5.   TypedListDAO dao = new TypedListDAO();  
  6.   return (int) dao.GetScalar(fields, nullnullnullnull);  
  7.   } 

  如果使用這個(gè)模板,下面的代碼已經(jīng)為你生成好了,直接使用即可。

  1.   private int GetSQLServerYear()  
  2.   {  
  3.   ResultsetFields fields = new ResultsetFields(1);  
  4.   fields.DefineField(new EntityField("AFld", SqlFunctionFactory.Year(DateTime.Today), 0);  
  5.   TypedListDAO dao = new TypedListDAO();  
  6.   return (int) dao.GetScalar(fields, nullnullnullnull);  
  7.   } 

  也就是說(shuō)白了,用于簡(jiǎn)化對(duì)SQL Server函數(shù)的調(diào)用方法。

  但是,上面的代碼僅僅是對(duì)SQL Server內(nèi)置的函數(shù)有作用,還沒有為用戶自定義的函數(shù)生成C#代碼,如果你有一個(gè)自定義的函數(shù)SomeFunctionToGetASetting,則需要添加一個(gè)partial的SqlFunctionFactory類,代碼如下

  1.   public partial class SqlFunctionFactory  
  2.   {  
  3.   public static IExpression SomeFunctionToGetASetting(int someParameter)  
  4.   {  
  5.   return new DbFunctionCall("dbo""SomeFunctionToGetASetting"new object[] { someParameter });  
  6.   }  
  7.   } 

  再增加一層代碼,供客戶端方便調(diào)用

  1.   public partial class SqlFunctionCalls  
  2.   {  
  3.   private SqlFunctionCalls()  
  4.   {  
  5.   }  
  6.   public static bool SomeFunctionToGetASetting(int someParameter)  
  7.   {  
  8.   return (bool)SqlFunctionFactory.GetScalar(SqlFunctionFactory.SomeFunctionToGetASetting(someParameter));  
  9.   }  
  10.   } 

  最終的調(diào)用代碼像下面這樣

  bool someSetting=SqlFunctionCalls.SomeFunctionToGetASetting(12);

  總結(jié):LLBL Gen的模板生成器Template Studio由于其商業(yè)性的原因,普及程度不高,入門起來(lái)也沒有Code Smith/T4之類的快速,文檔少。官方認(rèn)為,大部分的可能情況下,你不需要使用到自定義模板,LLBL Gen的安裝程序包已經(jīng)附帶了完整的Adapter/SelfServicing模板。但如果要徹底的把握LLBL Gen這一ORM工具,了解和學(xué)習(xí)它的模板技術(shù),是很有必要的。

原文鏈接:http://www.cnblogs.com/JamesLi2015/archive/2011/08/31/2160285.html

責(zé)任編輯:彭凡 來(lái)源: 博客園
相關(guān)推薦

2022-02-16 09:01:33

編程工具Node-RED編輯器

2021-04-18 20:46:30

工具代碼編程

2020-10-10 14:57:16

代碼開發(fā)工具

2022-05-26 17:40:51

Linux開源

2021-10-10 12:17:06

Weakpass在線字典生成器安全工具

2011-05-30 13:43:55

2019-08-30 08:00:00

WebminWebLinux

2023-09-21 11:48:49

CodeGeeXAI代碼

2022-02-25 14:57:33

harmonyOSjava心形動(dòng)畫

2021-07-07 06:52:17

云圖word-cloud工具

2023-07-11 08:30:56

2021-01-27 07:24:38

TypeScript工具Java

2024-01-25 10:40:11

AutoProfil開源分析工具

2019-11-05 18:50:37

代碼開發(fā)工具

2011-01-04 09:20:00

2021-01-27 13:16:39

ScreenLinux命令

2021-02-16 10:58:50

ScreenLinux命令

2023-10-08 07:51:07

HInvoke項(xiàng)目函數(shù)

2013-10-15 09:26:12

2020-12-22 10:30:47

Nagios工具監(jiān)控
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 亚洲1区 | 依人成人| 九九热九九 | 欧美精品一区二区三区在线播放 | 91在线精品视频 | 黑人精品欧美一区二区蜜桃 | 91热在线| 日韩精品视频在线 | 一区二区在线不卡 | 一级高清| 一区二区三区久久久 | 天天视频成人 | av在线播放网 | 欧美 日韩 中文 | 日韩视频一区二区 | 91精品国产91久久久久福利 | 婷婷久久五月 | 亚洲a毛片 | 少妇精品亚洲一区二区成人 | 中文字幕欧美在线观看 | 天天影视色综合 | 久久精品69 | 亚洲欧美国产精品一区二区 | 久久久久国产精品午夜一区 | 日韩在线欧美 | 午夜影院在线 | www日本在线播放 | 一区二区三区精品视频 | 国产日韩久久久久69影院 | 亚洲九九| www,黄色,com| 在线免费观看黄a | 日韩av.com| 日本在线视频一区二区 | www.激情.com| 国产欧美日韩一区 | 日韩精品视频在线播放 | 一区二区三区四区电影视频在线观看 | 欧美成人a∨高清免费观看 欧美日韩中 | 成人福利影院 | 久草视频在线播放 |