一:下载与激活

1.下载绿色版CodeSmith7.0

http://download.csdn.net/download/laoge/6859701

2.使用激活工具CodesmithKeyGenerator.exe激活CodeSmith7.0

(a)打开软件TemplateEditor.exe,进入CodeSmith Generator窗口,点击Register按钮;

(b)先打开激活工具CodesmithKeyGenerator.exe,进入CodeSmith KeyGenerator窗口,在Prefix里面输入:CS70P-    ,其他的保持默认,点击Generate按钮,产生serial序列号;

(c)复制serial中假的序列号到CodeSmith Generator窗口中serial number下,在CodeSmith Generator窗口填写name;

(d)点击Register按钮,点击Actiave by Entering a Code按钮,记住Machine Code中的序列号;

(e)切换到CodeSmith KeyGenerator窗口,点击Generate Activation按钮;

(f)在Prefix里面输入CS70P-  ,code里面选择时间(大于现在时间就行),手动输入Machine Code中的序列号到Machine Hash Code文本框里面,点击Generate按钮,产生真正的Activate序列号;

(g)把真正的Activate序列号复制到Activation Code文本框里面,点击Activate激活CodeSmith;

(h)运行TemplateEditor.exe,点击“Help—>About CodeSmith Generator”,如果Licensed to下显示你在(c)步输入的name,表示激活成功了。

二:CodeSmith的工作原理

①去数据库获取数据库的结构,如各个表的名称,表的字段,表间的关系等等;

②根据用户自定义好的模板文件,用数据库结构中的关键字替代模板的动态变量;

③输出并保存为我们需要的目标文件。

在CodeSmith中你可以自己定义模板来生成所有你想要的代码,也可以到CodeSmith社区http://community.codesmithtools.com/中去下载模板。

三:实例——使用CodeSmith生成分层架构的实体层

具体参照:http://www.cnblogs.com/huangcong/archive/2010/06/14/1758201.html

1.运行TemplateEditor.exe,新建CSharp Template取名为test.cst,添加代码(声明模板使用哪种语言,使CodeSmit和数据库关联起来);

<%@ CodeTemplate Language="C#" TargetLanguage="Text" Src="" Inherits="" Debug="False" CompilerVersion="v3.5" Description="Tempalte description here." %><%-- 加载访问数据库的组件SchemaExplorer,并声明其使用的命名空间 --%>
<%@ Assembly Name="SchemaExplorer"%>
<%@ Import Namespace="SchemaExplorer"%><%-- 数据库 --%>
<%@ Property Name="SourceDatabase" Type="SchemaExplorer.DatabaseSchema" 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."%>

2.新建一个文件Entity.cst,保存到test.cst所在的文件夹内,编写设计模板代码;

<%@ CodeTemplate Inherits="CodeTemplate" TargetLanguage="Text" Description="NetTiers main template."Debug="True" ResponseEncoding="UTF-8"%><%@ Assembly Name="SchemaExplorer"%>
<%@ Import Namespace="SchemaExplorer"%><%-- 要打印的表 --%>
<%@ Property Name="Table" Type="TableSchema" 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 in Table.Columns){ %>public <%= col.DataType %> <%=col.Name %>{ get;set; }<% } %>}
}

3.模板创建好后,要在test.cst文件中注册一下;

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

4.在test.cst中设置目标文件的输出目录;

<script runat="template">//解决方案输出路径
private string Directory = String.Empty;[Editor(typeof(System.Windows.Forms.Design.FolderNameEditor), typeof(System.Drawing.Design.UITypeEditor))] [Optional, NotChecked][DefaultValue("")]public string OutputDirectory { get{return Directory;}set{if (value.EndsWith("\\")) value = value.Substring(0, value.Length -1);Directory = value;} }
</script>

5.在test.cst中写些函数来完成将数据库架构传递给模板的工作;

<script runat="template">//生成实体Entity类
private void GenerateEntityClasses(){CodeTemplate Template =new EntityTemplate();foreach(TableSchema table in this.SourceDatabase.Tables){string FileDirectory = OutputDirectory +"\\"+ table.Name +".cs";//生成模板Template.SetProperty("Table",table);//文件输出Template.RenderToFile(FileDirectory,true);Debug.WriteLine(FileDirectory +" 创建成功.");}}
</script>

6.在test.cst中调用刚刚写好的函数;

<%
//创建实体层Entity类
this.GenerateEntityClasses();Debug.WriteLine("OK");
%>

7.设置我们要导出的数据库和输出目录;

a.点击CodeSmith主窗体右上角Schema Explorer面板,点击图标添加要连接的数据库,填写三个参数:

Name(要连接的数据库名字),Provider Type(sql server数据库选择SqlSchemaProvider),Connection String(可点击后面的按钮,填写数据库所在服务器名字或ip、登录方式和数据库名)

测试连接成功后,创建数据库成功。

b.点击CodeSmith主窗体右下角Properities面板中SourceDatabase属性栏右侧的…按钮,弹出数据库设置对话框,选择创建好的test数据库;

c.点击CodeSmith主窗体右下角Properities面板中OutputDirectory属性栏右侧的…按钮,选择目标文件输出目录。

8.回到test.cst页面,点击Generate自动生成代码成功后,可到输出目录中查看到所有表的实体类文件。

注:也可以在entity.cst模板文件中选择某个table单独生成实体类。

更多CodeSmith知识参照:http://terrylee.cnblogs.com/archive/2005/12/28/306254.aspx


转载于:https://www.cnblogs.com/jjdmk/p/4435976.html

认识CodeSmith相关推荐

  1. CodeSmith应用(一)

    这个例子仅是一个简单的应用,在我翻译并学习完CodeSmith的英文帮助文档后,对CodeSmith有了一定的了解,开始着手编写一些CodeSmith应用模板,今天按照最早提到的例子自行编写了一个基于 ...

  2. CodeSmith 学习资料收集

    CodeSmith开发系列资料总结: CodeSmith基础系列:         1.CodeSmith基础(一)         2.CodeSmith基础(二)         3.CodeSm ...

  3. CodeSmith实用技巧(十四):使用Progress对象

    Progress对象可以在CodeSmith生成代码时给用户显示一个进度条,当生成代码的时间很长时非常有用.如果你使用的是CodeSmith Explorer,进度条将显示在Generate按钮的左边 ...

  4. CodeSmith实用技巧(十五):使用快捷键

    在CodeSmith中,以下几个快捷键有助于我们快速输入.<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:offi ...

  5. 黄聪:如何使用CodeSmith批量生成代码(转:http://www.cnblogs.com/huangcong/archive/2010/06/14/1758201.html)...

    先看看CodeSmith的工作原理: 简单的说:CodeSmith首先会去数据库获取数据库的结构,如各个表的名称,表的字段,表间的关系等等,之后再根据用户自定义好的模板文件,用数据库结构中的关键字替代 ...

  6. CodeSmith(2):对象和控制台

    CodeSmith对象 代码模板对象(CodeTemplate Object) 在模板中,"this"(或者"Me"在VB.NET中)在当前模板中代码代码模板对 ...

  7. CodeSmith(9)访问数据库多个表

    模版源代码; <%@ CodeTemplate Language="C#" TargetLanguage="Text"  Debug="True ...

  8. CodeSmith连接mysql

    先下载:http://dev.mysql.com/downloads/connector/net/  mysql-connector-net-6.6.4.msi 并安装.在安装目录XX:\XX\MyS ...

  9. 如何使用CodeSmith批量生成代码

    在上一篇我们已经用PowerDesigner创建好了需要的测试数据库,下面就可以开始用它完成批量代码生成的工作啦. 下面我会一步步的解释如何用CodeSmith实现预期的结果的,事先声明一下,在此只做 ...

  10. 修改CodeSmith中的SchemaExplorer.MySQLSchemaProvider

    修改C:\Program Files (x86)\CodeSmith\v6.5\Samples\Projects\CSharp\MySQLSchemaProvider\MySQLSchemaProvi ...

最新文章

  1. python第一章思维导图_阅读课本第一章内容后,使用思维导图画出你所理解的
  2. 商汤科技开源DAVIS2017视频目标分割冠军代码
  3. python 翻译库_有没有大神用Python Requests库翻译一下呢?
  4. 阿里数据:2020七大数据技术领域趋势展望
  5. 怎么设置tomcat的默认应用
  6. project进行it项目管理案例_全景项目案例集第18期:给团队打鸡血的最好方式
  7. Python代码规范(PEP8)问题及解决
  8. php 中文名称排序 源码,四种排序算法PHP实现类
  9. 你真的了解Android ViewGroup的draw和onDraw的调用时机吗
  10. abaqus实例手册_《ABAQUS 6.14超级学习手册》——1.5 ABAQUS帮助文档-阿里云开发者社区...
  11. 2021最新千月影视全新改版影视app系统源码(全开源)源码下载
  12. light动名词_英语中什么叫动名词?加ING的就是吗?
  13. 【linux内核分析与应用-陈莉君】系统调用机制
  14. (小甲鱼python)集合笔记合集一 集合(上)总结 集合的简单用法 集合的各种方法合集:子、交、并、补、差、对称差集、超集
  15. 优酷盗播引版权方围攻 视频大佬陷孤军奋战困局
  16. 幂级数和函数经典例题_幂级数和函数的几种常见解法
  17. java实现王者荣耀匹配规则,王者荣耀匹配机制(通俗版)
  18. 电脑故障一查通 软件教学
  19. 深度学习分布式训练框架 horovod (3)
  20. 让CS的头像支持GIF动画

热门文章

  1. 大数据产品推荐:金蜂巢大数据集成与脱敏系统
  2. 新版UNITY游戏(IL2CPP类型)使用内嵌型机器翻译插件XUnity.AutoTranslator的食用方法
  3. 【ENVI遥感影像分类】 监督、非监督分类
  4. 短视频从业者实操资料大全(含代运营案例+报价单+合同协议 +分镜头脚本+管理运营)共180份
  5. Rplidar学习(二)—— SDK库文件学习
  6. DHCP工作原理和报文格式
  7. 《PWM整流器及其控制》读书笔记-第二章-PWM整流器拓扑结构及原理
  8. OverFeat 阅读笔记
  9. 3DGIS合伙人招募
  10. 工商管理专业知识与实务(初级)【7】