
1、在《上篇》中我们通过T4模板为我们指定的数据表成功生成了我们需要的用于添加、修改和删除操作的存储过
互联网 2023-05-28 19:04:47
1、在《上篇》中我们通过T4模板为我们指定的数据表成功生成了我们需要的用于添加、修改和删除操作的存储过程。
2、但是这是一种基于单个文件的解决方案,即我们必须为每一个生成的存储过程建立一个模板。
3、如果我们提供一种基于多文件的代码生成方式,将会为编程人员带来极大的便利。
【资料图】
4、借助于T4 ToolBox这个开源工具箱,多文件的SQL Generator的实现变得异常简单。
5、[文中的例子可以从这里下载]目录二、创建自定义的Generator三、ProcedureGenerator如何被使用?一、多文件代码生成器会带来多大的便利?我们先来直观的感受一下较之《上篇》提供的单一文件的代码生成器,基于多文件的代码生成解决方案会为开发人员带来多大的便利。
6、 同样对于《上篇》创建的数据表T_PRODUCT,之前我们为了生成三个不同的存储过程,我们不得已需要创建3个不同的T4模板文件。
7、实际上我们更需要的方式只需要创建一个T4模板,让我们的SQL Generator自动为我们生成3个包含相应存储过程的.sql附属文件,如左图所示(点击看大图)。
8、有的时候,基于单个数据表的存储过程生成方式我们依然觉得不方便。
9、如果我们能够在T4模板文件中指定的数据表的列表,让我们的SQL Generator为列表的每一个数据表都生成CUD三个存储过程,这样的方式更加具有吸引力。
10、如右图所示(点击看大图),一个订单模块包含两个具有主子关系的两张表(T_ORDER和T_ORDER_DETAIL),现在我们在一个T4模板中指定这两个表明,通过SQL Generator可以帮助我们生成6个包含存储过程的.sql附属文件。
11、甚至有的时候我们连数据表列表都无需指定,让SQL Generator为所有的表都生成相应的存储过程。
12、我的例子中没有提供这样的功能,但是实现自来不会存在任何问题。
13、二、创建自定义的Generator在《上篇》中我创建了一个抽象的ProcedureTemplate类,以及三个基于生成CUD存储过程的具体ProcedureTemplate:InsertProcedureTemplate、UpdateProcedureTemplate和DeleteProcedureTemplate。
14、它们都将直接服务于我们今天将要提供的基于多文件的SQL Generator。
15、在《上篇》中,这四个Template分别定义在4个不同的TT文件中,3个具体的ProcedureTemplate通过<[emailprotected]>指令将抽象ProcedureTemplate模板文件包含过来。
16、由于我们将要创建的T4模板将会使用到这四个类,如果我们用四个<[emailprotected]>指令将四个TT文件包含过来,由于T4引擎将会导致对ProcedureTemplate的4次包含,最好将会导致变异问题。
17、个人觉得这应该算是T4引擎解析包含关系的一个局限性,为了解决这个问题我们不得不抽象的ProcedureTemplate和三个具体的ProcedureTemplate都合并成一个TT文件。
18、T4 ToolBox为类库中为了提供了一个抽象的T4Toolbox.Generator类用于实现多文件的代码生成。
19、为此我们创建一个TT模板文件,定义了如下一个继承自该类的ProcedureGenerator。
20、ProcedureGenerator的核心是通过属性Templates定义的类型为IEnumerable
21、而对于ProcedureGenerator的构造函数,处理定义了一个表示数据库连接字符串的databaseName的参数外,并以数组参数的形式指定了生成的存储过程基于的数据表名的列表。
22、<#@ import namespace="System.Collections.Generic" #><#@ include file="***.tt" #><#@ include file="***.tt" #><#+publicclass ProcedureGenerator : Generator{public IEnumerable
23、由于具体的文本转化逻辑都定义在了ProcedureTemplate中了,所以在这里我们需要遍历的ProcedureTemplate集合中每一个Template对象,调用RenderToFile方法将相应的存储过程的脚本写入以存储过程命名同名的.sql文件中。
24、三、ProcedureGenerator如何被使用?我们最后来看看我们创建的ProcedureGenerator最终如何被应用于具体的代码生成。
25、其实很简单,我们只需要创建相应的模板文件,通过<[emailprotected]>将定义ProcedureGenerator类的TT文件包含近来,最后以代码语句调用块(<#StatementCode#>)的形式实力化该对象,并调用Run方法即可。
26、在构造函数中指定数据库连接字符串的名称和数据表名的列表。
27、下面是基于但表的T4模板。
28、<#@ template language="C#" hostSpecific="true" debug="true" #><#@ include file="Templates***.tt" #><#new ProcedureGenerator("TestDb","T_PRODUCT").Run();#>下面是基于多表的T4模板:<#@ template language="C#" hostSpecific="true" debug="true" #><#@ include file="Templates***.tt" #><#new ProcedureGenerator("TestDb","T_ORDER","T_ORDER_DETAIL").Run();#>当你代码生成工作执行之后,会多出一个与TT文件同名的附属文件,你需要手工删除掉它。
29、从数据到代码--通过代码生成机制实现强类型编程[上篇]从数据到代码--通过代码生成机制实现强类型编程[下篇]从数据到代码--基于T4的代码生成方式创建代码生成器可以很简单:如何通过T4模板生成代码?[上篇]。
本文就为大家分享到这里,希望小伙伴们会喜欢。
1、在《上篇》中我们通过T4模板为我们指定的数据表成功生成了我们需要的用于添加、修改和删除操作的存储过
1、比如5mm是我们食指指甲的一半大小,铅笔头的一半大小。2、毫米、厘米、分米、米都是十进制,依次比平方
中新网吉隆坡5月27日电(记者陈悦)“文化互鉴,美美与共”中马作家学者交流座谈会26日在吉隆坡举行。刘震
人民网北京5月28日电(欧阳易佳)2023年全国林草科技活动周启动仪式今日在北京中国林业科学研究院举行。活
1、夫妇关系在人伦道德中处于非常重要的地位。2、上古时期没有婚姻制度,没有“夫妇”这个概念,因此,也就
材料扇贝丁100g、绞肉200g、青椒200g、高筋粉300g、料酒,酱油,蚝油,盐,姜末,胡椒粉,色拉油,香油,水
斯玛特三分偏出,怀特绝杀,凯尔特人104-103战胜热火,将系列赛拖进抢七。谈到斯玛特出手最后一球,马祖拉
1、让你的睫毛Up、Up、Up1 用棉签沾维E睡前涂在睫毛上;2 橄榄油有滋养毛发的作用;3 睡前用隔夜的茶水用化妆棉
5月28日晚7:30央视CCTV4中国国际频道将播出“爱在中国”温州篇此外CCTV4《中国舆论场》微信公众号19:00—1
5月28日上午,随着K7672列车缓缓驶离固安站,标志着京九铁路北京丰台至河北固安通勤列车正式开通,根据中国
1、风度翩翩释义风度:风采气度,指美好的举止姿态;翩翩:文雅的样子。2、举止文雅优美。3、形容举止洒脱。4
1、蛇在梦中出现是典型的具有性意味的意象,梦见蛇可能暗示你对性的感觉或是性生活的状态。2、也许你最近有
豆来为大家解答以上的问题。花印精粹美白面膜怎么样,花印精粹美白面膜这个很多人还不知道,现在让我们一起
1、能,但要有正确的预测观。2、心正,顺其自然就能预测准确。3、﹙顺其自然是指不违反事物的发展规律﹚我
1、一定要登上泰山顶峰,俯瞰群山豪情满怀。2、此句出自唐朝杜甫的《望岳》。3、原文:岱宗夫如何?齐鲁青