如何使用CodeSmith批量生成代码(原创)

上传人:飞*** 文档编号:43380564 上传时间:2018-06-05 格式:DOC 页数:32 大小:78.18KB
返回 下载 相关 举报
如何使用CodeSmith批量生成代码(原创)_第1页
第1页 / 共32页
如何使用CodeSmith批量生成代码(原创)_第2页
第2页 / 共32页
如何使用CodeSmith批量生成代码(原创)_第3页
第3页 / 共32页
如何使用CodeSmith批量生成代码(原创)_第4页
第4页 / 共32页
如何使用CodeSmith批量生成代码(原创)_第5页
第5页 / 共32页
点击查看更多>>
资源描述

《如何使用CodeSmith批量生成代码(原创)》由会员分享,可在线阅读,更多相关《如何使用CodeSmith批量生成代码(原创)(32页珍藏版)》请在金锄头文库上搜索。

1、如何使用CodeSmith批量生成代码(原创) 在上一篇我们已经用PowerDesigner创建好了需要的测试数据库,下面就可以开 始用它完成批量代码生成的工作啦.下面我会一步步的解释如何用CodeSmith实现预期的结果的,事先声明一下,在此 只做一个简单的Demo,并不详细的讲解CodeSmith各个强大的功能,有兴趣的朋友 可以打开CodeSmith的帮助文档了解.我只做个抛砖引玉,希望能激起大家更多思 想的火花先看看CodeSmith的工作原理:简单的说:CodeSmith首先会去数据库获取数据库的结构,如各个表的名称,表的 字段,表间的关系等等,之后再根据用户自定义好的模板文件,用数

2、据库结构中的 关键字替代模板的动态变量,最终输出并保存为我们需要的目标文件.好,原理清 楚了,就开始实践吧:1. 运行CodeSmith,可以看到如下界面:2. CodeSmith是创建模板的地方,首先当然是创建一个模板啦,点击工具栏最左边的 NewNew DocumentDocumentC#C# TemplateTemplate,如图所示:3. 点击运行按钮,运行结果如下:好,我们来分析为什么会得到这样的运行结果吧,点击运行窗口左下角的Templat e按钮返回模板设计窗口,可以发现,只要是没有被或者late“包含的文字均被直接输出了,这些以后就要被换成我们分层架 构中一些一成不变的模板代码

3、:4. 好了,简单了解啦一些CodeSmith的代码结构,下面就开始用它来生成我们的分层 代码吧,在此我就不介绍分层架构的概念了,不然就偏离主题了.为了能更简单明 了的说明,我们在此就只用CodeSmith生成分层架构的实体层吧.先看看如果我们 不使用CodeSmith需要手动敲出哪些代码:Major.csusing System;using System.Collections.Generic;using System.Linq;using System.Text;namespace Entitypublic partial class Majorpublic Int32 MajorID g

4、et;set; public String Name get;set; public String Remark get;set; Student.csusing System;using System.Collections.Generic;using System.Linq;using System.Text;namespace Entitypublic partial class Studentpublic String StudentID get;set; public Int32 MajorID get;set; public String Name get;set; public

5、Boolean Sex get;set; public Int32 Age get;set; public String Remark get;set; 我将两个文件中重复的代码使用黄色背景色加深了,我们可以发现,如果每个表 都要通过手动创建,那么将有大量的代码(黄色背景)需要复制粘贴操作,这些操 作是繁琐而没有任何意义的.因此,我们会希望将黄色背景部分的代码做成模板, 而其他变化的代码由数据库的结构动态生成,如此一来,我们就不用再为这些烦 人的复制粘贴操作懊恼了.5. 那么就开始我们的实践吧,就在刚刚创建好的文件开始吧,先随意保存到一个目 录下,命名为test.cst,test.cst,接着

6、删除多余的代码,只保留第一行,该行表明我们的模 板使用何种语言,这里我们使用C#.6. 参照CodeSmith的工作原理,我们首先要为CodeSmith提供一个数据库,要怎么使 它和SQL Server 2005关联起来呢?只要加上下面的代码就行了:7. 好了,有了数据库连接,接着还需要一个模板,为了便于管理,我们新建一个文件 用于设计模板,FileFileNewNewBlankBlank TemplateTemplate,并添加如下代码,最好保存到test.csttest.cst所在的文件夹内,命名为EntityEntity .cst.cst:接着继续添加如下代码:using System;

7、using System.Collections.Generic;using System.Linq;using System.Text;namespace Entitypublic partial class public get;set; 表示在此处输出表的名称为循环语句,在循环输出列信息.表示在此处输出列的类型表示在此处输出列的名称如图所示:8. 模板创建好后,要在test.cst文件中注册一下,不然人家怎么知道有你这么一个 模板存在呀,在test.cst文件继续输入如下代码:9. 好了,模板注册好了,根据CodeSmith工作原理,我们要结合模板和数据库结构来 批量生成代码啦,但是我们

8、生成的目标文件要输出到哪里呢?这时我们会需要一 个用户自定义属性,用于设置目标文件的输出目录,在test.cst文件的末尾输入 如下代码:代码 /解决方案输出路径private string Directory = String.Empty;Editor(typeof(System.Windows.Forms.Design.FolderNameEditor), typeof(System.Drawing.Design.UITypeEditor) Optional, NotCheckedDefaultValue(“)public string OutputDirectory getreturn

9、Directory;setif (value.EndsWith(“) value = value.Substring(0, value.Length - 1);Directory = value; 10. 现在连输出目录也有了,该想办法写些函数来完成将数据库架构传递给模板的工 作啦,在test.cst文件的末尾输入如下代码:代码 /生成实体Entity类private void GenerateEntityClasses()CodeTemplate Template = new EntityTemplate();foreach(TableSchema table in this.SourceD

10、atabase.Tables)string FileDirectory = OutputDirectory + “ + table.Name + “.cs“;/生成模板Template.SetProperty(“Table“,table);/文件输出Template.RenderToFile(FileDirectory,true);Debug.WriteLine(FileDirectory +“ 创建成功.“);CodeTemplateTemplate = new EntityTemplate(); 就是创建了一个新的模板foreach(TableSchematable in this. So

11、urceDatabase.Tables) 表示循环输出数据库中的表Template.SetProperty(“Table“,table); 就是向模板设置属性,还记得我们在Entity.cst里面设置了一个Table属性吗,我 们就是通过这个方法给这个属性设值的.Template.RenderToFile(FileDirectory,true); 表示将Temlate里的内容全部输出到FileDirectory目录中,true表示如果文件存 在直接覆盖.11. 函数写好了,离成功不远啦,我们在test.cst的最后再添加如下代码,用于调用刚 刚写好的函数.至此,模板文件的制作已经完成.12.

12、好啦,现在只要设置我们要导出的数据库和输出目录就可以运行看结果啦,点击C odeSmith主窗体右下角Properities面板中SourceDatabase属性栏右侧的按钮 ,弹出数据库设置对话框,我们要在此添加一个新的数据库连接:13. 点击Add按钮,属性设置如图,我们选择的是在前一章用PowerDesigner创建好的P D_test数据库:14. 点击OK,回到数据库选择对话框,选择刚刚创建好的数据库连接:15. 接着是设置目标文件输出目录,我在这里设置为桌面的一个新建文件夹:16. OK,万事俱备,可以点击运行按钮让CodeSmith为我们批量生成代码啦:打开生成的文件,就可以看到

13、我们期待看到的代码啦:好了,这些是基础,但是只要你掌握了这些就可以开始自己的CodeSmith之旅啦, 我也只能送大家到此咯其他更多的知识点希望大家能自行查看帮助文章或者上 网查询,很高兴又和大家分享了自己的一点心得,接下来想再回头复习一下设计 模式,也打算写一些文章,欢迎大家关注上述实践中的文件源代码:test.cst /生成实体Entity类private void GenerateEntityClasses()CodeTemplate Template = new EntityTemplate();foreach(TableSchema table in this.SourceDatab

14、ase.Tables)string FileDirectory = OutputDirectory + “ + table.Name + “.cs“;/生成模板Template.SetProperty(“Table“,table);/文件输出Template.RenderToFile(FileDirectory,true);Debug.WriteLine(FileDirectory +“ 创建成功.“);/解决方案输出路径private string Directory = String.Empty;Editor(typeof(System.Windows.Forms.Design.Folde

15、rNameEditor), typeof(System.Drawing.Design.UITypeEditor) Optional, NotCheckedDefaultValue(“)public string OutputDirectory getreturn Directory;setif (value.EndsWith(“) value = value.Substring(0, value.Length - 1);Directory = value; Entity.cst using System;using System.Collections.Generic;using System.Linq;using System.Text;namespace Entitypublic partial class public get;set; 出处:http:/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面 明显位置给出原文连接,否则保留追究法律责任的权利。哇,期考啦,怎么那么多考试啊快看书才行了Tag标签: CodeSmith 批量 生成 代码 Code Smith 原创

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 行业资料 > 其它行业文档

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号