如何使用CodeSmith批量生成代码(原创系列教程)

简介:

上一篇我们已经用PowerDesigner创建好了需要的测试数据库,下面就可以开始用它完成批量代码生成的工作啦.

下面我会一步步的解释如何用CodeSmith实现预期的结果的,事先声明一下,在此只做一个简单的Demo,并不详细的讲解CodeSmith各个强大的功能,有兴趣的朋友可以打开CodeSmith的帮助文档了解.我只做个抛砖引玉,希望能激起大家更多思想的火花~

先看看CodeSmith的工作原理:

简单的说:CodeSmith首先会去数据库获取数据库的结构,如各个表的名称,表的字段,表间的关系等等,之后再根据用户自定义好的模板文件,用数据库结构中的关键字替代模板的动态变量,最终输出并保存为我们需要的目标文件.好,原理清楚了,就开始实践吧:

1. 运行CodeSmith,可以看到如下界面:

2. CodeSmith是创建模板的地方,首先当然是创建一个模板啦,点击工具栏最左边的New DocumentC# Template,如图所示:

 

3. 点击运行按钮,运行结果如下:

好,我们来分析为什么会得到这样的运行结果吧,点击运行窗口左下角的Template按钮返回模板设计窗口,可以发现,只要是没有被<%%>或者<scriptrunat="template"></script>包含的文字均被直接输出了,这些以后就要被换成我们分层架构中一些一成不变的模板代码:

4. 好了,简单了解啦一些CodeSmith的代码结构,下面就开始用它来生成我们的分层代码吧,在此我就不介绍分层架构的概念了,不然就偏离主题了.为了能更简单明了的说明,我们在此就只用CodeSmith生成分层架构的实体层吧.先看看如果我们不使用CodeSmith需要手动敲出哪些代码:

Major.cs

复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace Entity
{
publicpartialclass
 Major
{
public Int32 MajorID get;set ; }
public String Name get;set ; }
public String Remark get;set ; }
}
}
复制代码

Student.cs

复制代码
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace Entity
{
publicpartialclass
 Student
{
public String StudentID get;set ; }
public Int32 MajorID get;set ; }
public String Name get;set ; }
public Boolean Sex get;set ; }
public Int32 Age get;set ; }
public String Remark get;set ; }
}
}
复制代码

我将两个文件中重复的代码使用黄色背景色加深了,我们可以发现,如果每个表都要通过手动创建,那么将有大量的代码(黄色背景)需要复制粘贴操作,这些操作是繁琐而没有任何意义的.因此,我们会希望将黄色背景部分的代码做成模板,而其他变化的代码由数据库的结构动态生成,如此一来,我们就不用再为这些烦人的复制粘贴操作懊恼了.

5. 那么就开始我们的实践吧,就在刚刚创建好的文件开始吧,先随意保存到一个目录下,命名为test.cst,接着删除多余的代码,只保留第一行,该行表明我们的模板使用何种语言,这里我们使用C#.

<% @ CodeTemplateLanguage = " C# "  TargetLanguage = " Text "  Src = ""  Inherits = "" Debug = " False "  CompilerVersion = " v3.5 " Description = " Template description here. " %>

6. 参照CodeSmith的工作原理,我们首先要为CodeSmith提供一个数据库,要怎么使它和SQL Server 2005关联起来呢?只要加上下面的代码就行了:

复制代码
<%--  加载访问数据库的组件SchemaExplorer,并声明其使用的命名空间  --%>
<% @ AssemblyName = " SchemaExplorer " %>
<% @ ImportNamespace = " SchemaExplorer " %>

<%--  数据库  --%>
<% @ PropertyName = " SourceDatabase " DeepLoad = " True "  Optional = " False "  Category = " 01. GettingStarted - Required "  Description = " Database that the tables views, and storedprocedures should be based on. IMPORTANT!!! If SourceTables and SourceViews areleft blank, the Entire Database will then be generated. " %>
复制代码

7. 好了,有了数据库连接,接着还需要一个模板,为了便于管理,我们新建一个文件用于设计模板,FileNewBlank  Template,并添加如下代码,最好保存到test.cst所在的文件夹内,命名为Entity.cst:

复制代码
< %@ CodeTemplateInherits = " CodeTemplate " TargetLanguage = " Text "  Description = " NetTiers main template. " Debug = " True "  ResponseEncoding = " UTF-8 " % >

< %@ AssemblyName = " SchemaExplorer "  % >
< %@ ImportNamespace = " SchemaExplorer "  % >

< % --  要打印的表  -- % >
< %@ PropertyName = " Table "  DeepLoad = " True " Optional = " False "  Category = " 01. Getting Started - Required " Description = " Database that the tables views, and stored procedures shouldbe based on. IMPORTANT!!! If SourceTables and SourceViews are left blank, theEntire Database will then be generated. "  % >
复制代码

接着继续添加如下代码:

复制代码
using  System;
using System.Collections.Generic;
using  System.Linq;
using  System.Text;

namespace  Entity
{
public partial class <%=  Table.Name %>
{
<% foreach (ColumnSchema col inTable.Columns){  %>
public <%=  col.DataType  %> <%= col.Name  %> get ; set ; }
<%  }  %>
}
}
复制代码

<%=Table.Name%>          表示在此处输出表的名称

<%foreach(ColumnSchema col in Table.Columns){ %> <% } %>       为循环语句,在{}循环输出列信息.

<%=col.DataType %>       表示在此处输出列的类型

<%=col.Name %>             表示在此处输出列的名称

如图所示:

8. 模板创建好后,要在test.cst文件中注册一下,不然人家怎么知道有你这么一个模板存在呀,在test.cst文件继续输入如下代码:

<%--  注册实体层Entity模板  --%>
<% @ RegisterName = " EntityTemplate "  Template = "  Entity.cst " MergeProperties = " Flase "  ExcludeProperties = "" %>

9. 好了,模板注册好了,根据CodeSmith工作原理,我们要结合模板和数据库结构来批量生成代码啦,但是我们生成的目标文件要输出到哪里呢?这时我们会需要一个用户自定义属性,用于设置目标文件的输出目录,在test.cst文件的末尾输入如下代码:

代码

10. 现在连输出目录也有了,该想办法写些函数来完成将数据库架构传递给模板的工作啦,在test.cst文件的末尾输入如下代码:

代码

CodeTemplateTemplate = new EntityTemplate();  就是创建了一个新的模板

foreach(TableSchematable in this. SourceDatabase.Tables){}    表示循环输出数据库中的表

Template.SetProperty("Table",table);                         就是向模板设置属性,还记得我们在Entity.cst里面设置了一个Table属性吗,我们就是通过这个方法给这个属性设值的.

Template.RenderToFile(FileDirectory,true);               表示将Temlate里的内容全部输出到FileDirectory目录中,true表示如果文件存在直接覆盖.

11. 函数写好了,离成功不远啦,我们在test.cst的最后再添加如下代码,用于调用刚刚写好的函数.至此,模板文件的制作已经完成.

复制代码
<%
// 创建实体层Entity类
this .GenerateEntityClasses();

Debug.WriteLine(
" OK " );
%>
复制代码

12. 好啦,现在只要设置我们要导出的数据库和输出目录就可以运行看结果啦,点击CodeSmith主窗体右下角Properities面板中SourceDatabase属性栏右侧的…按钮,弹出数据库设置对话框,我们要在此添加一个新的数据库连接:

13. 点击Add按钮,属性设置如图,我们选择的是在前一章用PowerDesigner创建好的PD_test数据库:

14. 点击OK,回到数据库选择对话框,选择刚刚创建好的数据库连接:

15. 接着是设置目标文件输出目录,我在这里设置为桌面的一个新建文件夹:

16. OK,万事俱备,可以点击运行按钮让CodeSmith为我们批量生成代码啦:

打开生成的文件,就可以看到我们期待看到的代码啦:

好了,这些是基础,但是只要你掌握了这些就可以开始自己的CodeSmith之旅啦,我也只能送大家到此咯~其他更多的知识点希望大家能自行查看帮助文章或者上网查询,很高兴又和大家分享了自己的一点心得,接下来想再回头复习一下设计模式,也打算写一些文章,欢迎大家关注~

上述实践中的文件源代码:

test.cst
Entity.cst

哇,期考啦,怎么那么多考试啊~~~~快看书才行了~~~~




本文转自黄聪博客园博客,原文链接:http://www.cnblogs.com/huangcong/archive/2010/06/14/1758201.html,如需转载请自行联系原作者

相关文章
|
1月前
|
测试技术 Serverless 数据库
python测试代码(一)
python测试代码(一)
17 1
|
11月前
|
应用服务中间件
主要介绍了解决IDEA控制台乱码的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,
主要介绍了解决IDEA控制台乱码的方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,
|
中间件 C#
MasaFramework入门第二篇,安装MasaFramework了解各个模板
MasaFramework入门第二篇,安装MasaFramework了解各个模板
176 0
MasaFramework入门第二篇,安装MasaFramework了解各个模板
|
编解码 算法 Java
java编程中遇到的部分问题【点击文中参考解答】
java编程中遇到的部分问题【点击文中参考解答】
142 0
|
Linux Shell 数据安全/隐私保护
python接口自动化(三十二)--Python发送邮件(常见四种邮件内容)番外篇——上(详解)
本篇文章与前边没有多大关联,就是对前边有关发邮件的总结和梳理。在写脚本时,放到后台运行,想知道执行情况,会通过邮件、SMS(短信)、飞信、微信等方式通知管理员,用的最多的是邮件。在linux下,Shell脚本发送邮件告警是件很简单的事,有现成的邮件服务软件或者调用运营商邮箱服务器
138 0
python接口自动化(三十二)--Python发送邮件(常见四种邮件内容)番外篇——上(详解)
|
消息中间件 缓存 Kafka
【随笔】学习记录、实用脚本
文章目录 工作随笔 一、kafka 1.1 基础命令 二、es 1.1 基础命令 三、实用小脚本 3.1 判断文件中是否有某个对应的值
88 0
【随笔】学习记录、实用脚本
|
数据采集 数据可视化 JavaScript
python实现3d图表,对掘金后端作者进行可视化操作|Python 主题月
今天来和小伙伴们介绍点不一样的~ 哈哈 😝 如下图~ image-20210711123925505 看到这图你想到什么了呢~ img 其实只是我无聊,找个地方练练爬虫 哈哈,然后对数据进行可视化操作,就有了这么一个3d图表 而且还是有点小收获的,让我来简单介绍下先吧! 爬取的目标 如图所示,此次爬取的目标是 后端排行榜 ,没错 就是这么些数据,然后对作者对应的赞,等级,进行可视化操作 image-20210711130057215 API
117 0
ADI
[随笔]Electorn 代码片段
[随笔]Electorn 代码片段
ADI
107 0
|
存储 数据库 数据安全/隐私保护
MFC应用程序编写实例—完整版(原创)
前段时间,将近花了一周至两周上班和上班后的闲余时间,做了一个用于调试和测试工作项目的应用软件,下面将实现软件的重要步骤及主要功能讲解一遍,方便日后查阅。 程序开始后,提示登录框,输入用户名,密码后,登录进去主窗体,效果图如下:   下面将主要实现的功能函数要点进行描述,具体实现如下:  ...
1045 0
|
JavaScript 前端开发
前端JS的一些使用方法-持续更新
1.JS格式化时间方法 格式一: 2018-1-29-10:34:49       var curr_time = new Date();       Myformatter(curr_t...
1190 0

热门文章

最新文章