- 浏览: 660755 次
文章分类
最新评论
-
richondow:
Android实战开发租赁管理软件百度网盘下载:链接:http ...
Android实战开发租赁管理软件(适配UI,数据的存储,多线程下载)课程分享 -
古老的传言:
大哥,课程还有吗?有的话可否发一份给我?我的邮箱7606089 ...
马哥Linux系列七:实战大数据技术专题(Hadoop、NoSQL、Zookeeper、MapReduce)课程分享 -
kgtw:
1223137028@qq.com求发一份
基于Lucene4.6+Solr4.6+Heritrix1.14+S2SH实战开发从无到有垂直搜索引擎
如何用CodeSmith减少代码重复编写
如果说代码生成工具仅仅是自动生成for循环代码或者是include头文件,或者是类定义,那么它对我而言还没有太大的意义,因为我平时工作也达不到“手指在键盘上飞舞”的状态。思考的时间远大于写代码的时间。我不会感到写个for循环会影响到我的工作效率。但是看了下面的文章,我感到这种代码生成工具还是非常有意义的。我之前看到服务端的同事写个状态过程写的异常辛苦,而且中间各种问题(例如写了一半编辑器崩溃了,之前的没有保存。。。),但是这个工作又纯粹是体力活。所以我当时就问,这个东西不是可以写个脚本来做吗? CodeSmith就是我们需要的。
CodeSmith是一种语法类似于asp.net的基于模板的代码生成器,程序可以自定义模板,从而减少重复编码的劳动量,提高效率。
安装CodeSmith 2.6注册后发现有两个可运行程序CodeSmith Studio.exe和CodeSmith Explorer.exe
CodeSmith Studio.exe用来创建自定义模板
CodeSmith Explorer.exe用来导入模板并且生成代码
打开CodeSmith Studio.exe,新建一个C#模板。发现有如下类似与asp.net的标识符号
<% %>
<%= %>
<%@ %>
<script runat="template"> </script>
下面通过简单的例子说明如何用 CodeSmith创建模板并生成代码
新建一个空的txt文件,在文件上部输入如下一个CodeTemplate指示,Language和TargetLanguage分别代表模板语言和创建代码语言,
<%@
CodeTemplate Language="C#" TargetLanguage="C#" Description="Generates a simple class " %>
然后声明几个变量,用来为了能够在以后生成的代码嵌入,这里声明了三个名为NameSpace,ClassName,Contxt的变量。其他参数一目了然就不再说明了,
<%@
Property Name="NameSpace" Type="String"
Category="Context"
Description="The namespace to use for this class" %>
<%@
Property Name="ClassName" Type="String"
Category="Context"
Description="The name of the class to generate" %>
<%@
Property Name="DevelopersName" Type="String"
Category="Context"
Description="The name to include in the comment header" %>
接下来建立将要生成代码的框架,在适当位置引用刚刚声明的变量名
usingSystem;
namespace<%=NameSpace
%>
{
///<summary>
///Summary
description for<%=ClassName %>.
///</summary>
publicclass<%=ClassName
%>
{
public<%=ClassName
%>()
{
}
}
}
最后,打开CodeSmith Explorer.exe,加载此模板,并且在属性对话框中任意更改声明的变量名,按Generate按钮生成合适的代码
以上简单的说明了CodeSmith的功能
下面看看在数据库访问中它是如何最小化我们的工作的
在这里我们要用到CodeSmith API中一个叫SchemaExplorer的组件,它提供了一系列类来操作数据库的框架,我们可以用它来创建表和存储过程,得到字段类型,字段名等。
如下是更新NorthWind数据库中orders表记录的存储过程,我们来看看如何自动生成它
CREATE
PROCEDURE dbo.UpdateOrders
@OrderIDint,
@CustomerID nchar(5),
@EmployeeIDint,
@OrderDate datetime,
@RequiredDate datetime,
@ShippedDate datetime,
@ShipViaint,
@Freight money,
@ShipName nvarchar(40),
@ShipAddress nvarchar(60),
@ShipCity nvarchar(15),
@ShipRegion nvarchar(15),
@ShipPostalCode nvarchar(10),
@ShipCountry nvarchar(15)
AS
UPDATE
[Orders] SET
[CustomerID] = @CustomerID,
[EmployeeID] = @EmployeeID,
[OrderDate] = @OrderDate,
[RequiredDate] = @RequiredDate,
[ShippedDate] = @ShippedDate,
[ShipVia] = @ShipVia,
[Freight] = @Freight,
[ShipName] = @ShipName,
[ShipAddress] = @ShipAddress,
[ShipCity] = @ShipCity,
[ShipRegion] = @ShipRegion,
[ShipPostalCode] = @ShipPostalCode,
[ShipCountry] = @ShipCountry
WHERE
[OrderID] = @OrderID
第一步还是创建一个CodeTemplate指示,注意TargetLanguage属性改为了T-SQL,因为创建的SQL语言代码
<%@ CodeTemplate Language="C#" TargetLanguage="T-SQL" Description="Generates a update stored procedure." %>
然后加载SchemaExplorer组件,并导入SchemaExplorer命名空间,看这里是不是和asp.net很像
<%@
Assembly Name="SchemaExplorer" %>
<%@
Import Namespace="SchemaExplorer" %>
接下来声明变量,因为要从数据库表中读取框架所以Type属性为SchemaExplorer.TableSchema
<%@
Property Name="SourceTable" Type="SchemaExplorer.TableSchema" Category="Context" Description="Table that the stored procedures should be based on." %>
下面就要写实际将要输出代码部分的模板了。
先写存储过程的第一行,<%%>内为引用前面声明变量名,代表表名
CREATE PROCEDURE dbo.Update<%=SourceTable.Name %>
第二步为存储过程创造将要声明的参数列表
//开始循环遍历每列
<%for(inti = 0; i < SourceTable.Columns.Count; i++){ %>
//传递每列给GetSqlParameterStatement函数
<%= GetSqlParameterStatement(SourceTable.Columns[i]) %>
//循环结束条件
<%if(i < SourceTable.Columns.Count - 1){ %>,<% }%>
<% }% >
AS
定义GetSqlParameterStatement方法接受列参数返回参数名,和字段类型,注意函数要放在
<script runat="template"></script>里
<script
runat="template">
publicstringGetSqlParameterStatement(ColumnSchema
column)
{
stringparam
= "@" + column.Name + " " + column.NativeType;
switch(column.DataType)
{
caseDbType.Decimal:
{
param += "(" + column.Precision + ", " + column.Scale + ")";
break;
}
default:
{
if(column.Size
> 0)
{
param += "(" + column.Size + ")";
}
break;
}
}
returnparam;
}
</script>
接下来创建存储过程的Update部分,语法类似不再说明
UPDATE
[<%= SourceTable.Name %>] SET
<%for(inti = 0; i < SourceTable.NonPrimaryKeyColumns.Count; i++){ %>
[<%= SourceTable.NonPrimaryKeyColumns[i].Name %>] = @<%= SourceTable.NonPrimaryKeyColumns[i].Name %><%if(i < SourceTable.NonPrimaryKeyColumns.Count - 1){ %>,<% }%>
<% }%>
//where条件,注意主键提取方法
WHERE
<%for(inti = 0; i < SourceTable.PrimaryKey.MemberColumns.Count; i++){ %>
<%if(i > 0){ %>AND <% }%>
[<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>] = @<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>
<% }%>
最终为模板为如下形式
<%@ CodeTemplate Language="C#" TargetLanguage="T-SQL"
Description="Generates a update stored procedure." %>
<%@ Property Name="SourceTable" Type="SchemaExplorer.TableSchema"
Category="Context"
Description="Table that the stored procedures should be based on." %>
<%@ Assembly Name="SchemaExplorer" %>
<%@ Import Namespace="SchemaExplorer" %>
<script runat="template">
publicstringGetSqlParameterStatement(ColumnSchema column)
{
stringparam = "@" + column.Name + " " + column.NativeType;
switch(column.DataType)
{
caseDbType.Decimal:
{
param += "(" + column.Precision + ", " + column.Scale + ")";
break;
}
default:
{
if(column.Size > 0)
{
param += "(" + column.Size + ")";
}
break;
}
}
returnparam;
}
</script>
CREATE PROCEDURE dbo.Update<%= SourceTable.Name %>
<%for(inti = 0; i < SourceTable.Columns.Count; i++) { %>
<%= GetSqlParameterStatement(SourceTable.Columns[i]) %><%if(i < SourceTable.Columns.Count - 1) { %>,<% } %>
<% } %>
AS
UPDATE [<%= SourceTable.Name %>] SET
<%for(inti = 0; i < SourceTable.NonPrimaryKeyColumns.Count; i++) { %>
[<%= SourceTable.NonPrimaryKeyColumns[i].Name %>] = @<%= SourceTable.NonPrimaryKeyColumns[i].Name %><%if(i < SourceTable.NonPrimaryKeyColumns.Count - 1) { %>,<% } %>
<% } %>
WHERE
<%for(inti = 0; i < SourceTable.PrimaryKey.MemberColumns.Count; i++) { %>
<%if(i > 0) { %>AND <% } %>
[<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>] = @<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>
<% } %>
将其用CodeSmith Explorer.exe打开
可以任意选择数据库中的表,这里选择NorthWind中的0rders表
然后生成代码,就创建好了存储过程
CREATE
PROCEDURE dbo.UpdateOrders
@OrderIDint,
@CustomerID nchar(5),
@EmployeeIDint,
@OrderDate datetime,
@RequiredDate datetime,
@ShippedDate datetime,
@ShipViaint,
@Freight money,
@ShipName nvarchar(40),
@ShipAddress nvarchar(60),
@ShipCity nvarchar(15),
@ShipRegion nvarchar(15),
@ShipPostalCode nvarchar(10),
@ShipCountry nvarchar(15)
AS
UPDATE
[Orders] SET
[CustomerID] = @CustomerID,
[EmployeeID] = @EmployeeID,
[OrderDate] = @OrderDate,
[RequiredDate] = @RequiredDate,
[ShippedDate] = @ShippedDate,
[ShipVia] = @ShipVia,
[Freight] = @Freight,
[ShipName] = @ShipName,
[ShipAddress] = @ShipAddress,
[ShipCity] = @ShipCity,
[ShipRegion] = @ShipRegion,
[ShipPostalCode] = @ShipPostalCode,
[ShipCountry] = @ShipCountry
WHERE
[OrderID] = @OrderID
同样,我们可以选择其他的表创建Updata存储过程,也可以自定义其他诸如insert delete等的存储过程,是不是很方便?^-^
以上只是CodeSmith的简单应用,还有其他的功能有待大家探索了。
关于CodeSmith社区一些模板资源,大家可以去如下地址选择下载
CodeSmith Peer Support Forum
Codesmith templates library
CodeSmith是一种语法类似于asp.net的基于模板的代码生成器,程序可以自定义模板,从而减少重复编码的劳动量,提高效率。
安装CodeSmith 2.6注册后发现有两个可运行程序CodeSmith Studio.exe和CodeSmith Explorer.exe
CodeSmith Studio.exe用来创建自定义模板
CodeSmith Explorer.exe用来导入模板并且生成代码
打开CodeSmith Studio.exe,新建一个C#模板。发现有如下类似与asp.net的标识符号
<% %>
<%= %>
<%@ %>
<script runat="template"> </script>
下面通过简单的例子说明如何用 CodeSmith创建模板并生成代码
新建一个空的txt文件,在文件上部输入如下一个CodeTemplate指示,Language和TargetLanguage分别代表模板语言和创建代码语言,
<%@
CodeTemplate Language="C#" TargetLanguage="C#" Description="Generates a simple class " %>
然后声明几个变量,用来为了能够在以后生成的代码嵌入,这里声明了三个名为NameSpace,ClassName,Contxt的变量。其他参数一目了然就不再说明了,
<%@
Property Name="NameSpace" Type="String"
Category="Context"
Description="The namespace to use for this class" %>
<%@
Property Name="ClassName" Type="String"
Category="Context"
Description="The name of the class to generate" %>
<%@
Property Name="DevelopersName" Type="String"
Category="Context"
Description="The name to include in the comment header" %>
接下来建立将要生成代码的框架,在适当位置引用刚刚声明的变量名
usingSystem;
namespace<%=NameSpace
%>
{
///<summary>
///Summary
description for<%=ClassName %>.
///</summary>
publicclass<%=ClassName
%>
{
public<%=ClassName
%>()
{
}
}
}
最后,打开CodeSmith Explorer.exe,加载此模板,并且在属性对话框中任意更改声明的变量名,按Generate按钮生成合适的代码
以上简单的说明了CodeSmith的功能
下面看看在数据库访问中它是如何最小化我们的工作的
在这里我们要用到CodeSmith API中一个叫SchemaExplorer的组件,它提供了一系列类来操作数据库的框架,我们可以用它来创建表和存储过程,得到字段类型,字段名等。
如下是更新NorthWind数据库中orders表记录的存储过程,我们来看看如何自动生成它
CREATE
PROCEDURE dbo.UpdateOrders
@OrderIDint,
@CustomerID nchar(5),
@EmployeeIDint,
@OrderDate datetime,
@RequiredDate datetime,
@ShippedDate datetime,
@ShipViaint,
@Freight money,
@ShipName nvarchar(40),
@ShipAddress nvarchar(60),
@ShipCity nvarchar(15),
@ShipRegion nvarchar(15),
@ShipPostalCode nvarchar(10),
@ShipCountry nvarchar(15)
AS
UPDATE
[Orders] SET
[CustomerID] = @CustomerID,
[EmployeeID] = @EmployeeID,
[OrderDate] = @OrderDate,
[RequiredDate] = @RequiredDate,
[ShippedDate] = @ShippedDate,
[ShipVia] = @ShipVia,
[Freight] = @Freight,
[ShipName] = @ShipName,
[ShipAddress] = @ShipAddress,
[ShipCity] = @ShipCity,
[ShipRegion] = @ShipRegion,
[ShipPostalCode] = @ShipPostalCode,
[ShipCountry] = @ShipCountry
WHERE
[OrderID] = @OrderID
第一步还是创建一个CodeTemplate指示,注意TargetLanguage属性改为了T-SQL,因为创建的SQL语言代码
<%@ CodeTemplate Language="C#" TargetLanguage="T-SQL" Description="Generates a update stored procedure." %>
然后加载SchemaExplorer组件,并导入SchemaExplorer命名空间,看这里是不是和asp.net很像
<%@
Assembly Name="SchemaExplorer" %>
<%@
Import Namespace="SchemaExplorer" %>
接下来声明变量,因为要从数据库表中读取框架所以Type属性为SchemaExplorer.TableSchema
<%@
Property Name="SourceTable" Type="SchemaExplorer.TableSchema" Category="Context" Description="Table that the stored procedures should be based on." %>
下面就要写实际将要输出代码部分的模板了。
先写存储过程的第一行,<%%>内为引用前面声明变量名,代表表名
CREATE PROCEDURE dbo.Update<%=SourceTable.Name %>
第二步为存储过程创造将要声明的参数列表
//开始循环遍历每列
<%for(inti = 0; i < SourceTable.Columns.Count; i++){ %>
//传递每列给GetSqlParameterStatement函数
<%= GetSqlParameterStatement(SourceTable.Columns[i]) %>
//循环结束条件
<%if(i < SourceTable.Columns.Count - 1){ %>,<% }%>
<% }% >
AS
定义GetSqlParameterStatement方法接受列参数返回参数名,和字段类型,注意函数要放在
<script runat="template"></script>里
<script
runat="template">
publicstringGetSqlParameterStatement(ColumnSchema
column)
{
stringparam
= "@" + column.Name + " " + column.NativeType;
switch(column.DataType)
{
caseDbType.Decimal:
{
param += "(" + column.Precision + ", " + column.Scale + ")";
break;
}
default:
{
if(column.Size
> 0)
{
param += "(" + column.Size + ")";
}
break;
}
}
returnparam;
}
</script>
接下来创建存储过程的Update部分,语法类似不再说明
UPDATE
[<%= SourceTable.Name %>] SET
<%for(inti = 0; i < SourceTable.NonPrimaryKeyColumns.Count; i++){ %>
[<%= SourceTable.NonPrimaryKeyColumns[i].Name %>] = @<%= SourceTable.NonPrimaryKeyColumns[i].Name %><%if(i < SourceTable.NonPrimaryKeyColumns.Count - 1){ %>,<% }%>
<% }%>
//where条件,注意主键提取方法
WHERE
<%for(inti = 0; i < SourceTable.PrimaryKey.MemberColumns.Count; i++){ %>
<%if(i > 0){ %>AND <% }%>
[<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>] = @<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>
<% }%>
最终为模板为如下形式
<%@ CodeTemplate Language="C#" TargetLanguage="T-SQL"
Description="Generates a update stored procedure." %>
<%@ Property Name="SourceTable" Type="SchemaExplorer.TableSchema"
Category="Context"
Description="Table that the stored procedures should be based on." %>
<%@ Assembly Name="SchemaExplorer" %>
<%@ Import Namespace="SchemaExplorer" %>
<script runat="template">
publicstringGetSqlParameterStatement(ColumnSchema column)
{
stringparam = "@" + column.Name + " " + column.NativeType;
switch(column.DataType)
{
caseDbType.Decimal:
{
param += "(" + column.Precision + ", " + column.Scale + ")";
break;
}
default:
{
if(column.Size > 0)
{
param += "(" + column.Size + ")";
}
break;
}
}
returnparam;
}
</script>
CREATE PROCEDURE dbo.Update<%= SourceTable.Name %>
<%for(inti = 0; i < SourceTable.Columns.Count; i++) { %>
<%= GetSqlParameterStatement(SourceTable.Columns[i]) %><%if(i < SourceTable.Columns.Count - 1) { %>,<% } %>
<% } %>
AS
UPDATE [<%= SourceTable.Name %>] SET
<%for(inti = 0; i < SourceTable.NonPrimaryKeyColumns.Count; i++) { %>
[<%= SourceTable.NonPrimaryKeyColumns[i].Name %>] = @<%= SourceTable.NonPrimaryKeyColumns[i].Name %><%if(i < SourceTable.NonPrimaryKeyColumns.Count - 1) { %>,<% } %>
<% } %>
WHERE
<%for(inti = 0; i < SourceTable.PrimaryKey.MemberColumns.Count; i++) { %>
<%if(i > 0) { %>AND <% } %>
[<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>] = @<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>
<% } %>
将其用CodeSmith Explorer.exe打开
可以任意选择数据库中的表,这里选择NorthWind中的0rders表
然后生成代码,就创建好了存储过程
CREATE
PROCEDURE dbo.UpdateOrders
@OrderIDint,
@CustomerID nchar(5),
@EmployeeIDint,
@OrderDate datetime,
@RequiredDate datetime,
@ShippedDate datetime,
@ShipViaint,
@Freight money,
@ShipName nvarchar(40),
@ShipAddress nvarchar(60),
@ShipCity nvarchar(15),
@ShipRegion nvarchar(15),
@ShipPostalCode nvarchar(10),
@ShipCountry nvarchar(15)
AS
UPDATE
[Orders] SET
[CustomerID] = @CustomerID,
[EmployeeID] = @EmployeeID,
[OrderDate] = @OrderDate,
[RequiredDate] = @RequiredDate,
[ShippedDate] = @ShippedDate,
[ShipVia] = @ShipVia,
[Freight] = @Freight,
[ShipName] = @ShipName,
[ShipAddress] = @ShipAddress,
[ShipCity] = @ShipCity,
[ShipRegion] = @ShipRegion,
[ShipPostalCode] = @ShipPostalCode,
[ShipCountry] = @ShipCountry
WHERE
[OrderID] = @OrderID
同样,我们可以选择其他的表创建Updata存储过程,也可以自定义其他诸如insert delete等的存储过程,是不是很方便?^-^
以上只是CodeSmith的简单应用,还有其他的功能有待大家探索了。
关于CodeSmith社区一些模板资源,大家可以去如下地址选择下载
CodeSmith Peer Support Forum
Codesmith templates library
相关推荐
CodeSmith 生成代码工具CodeSmith 生成代码工具CodeSmith 生成代码工具CodeSmith 生成代码工具CodeSmith 生成代码工具CodeSmith 生成代码工具CodeSmith 生成代码工具CodeSmith 生成代码工具
codesmith 代码模板,帮助开发生成代码使用
codesmith三层代码模板代码模板,codesmith三层代码模板代码模板,codesmith三层代码模板代码模板,codesmith三层代码模板代码模板,codesmith三层代码模板代码模板,codesmith三层代码模板代码模板。
CodeSmith好用的代码生成器 代码生成器 自定义
CodeSmith 5.3代码生成工具及模版 用过就知道了
CodeSmith 是一种基于模板的代码生成工具,它使用类似于ASP.NET的语法来生成任意类型的代码或文本,从而减少重复编码的劳动量,提高效率。与其他许多代码生成工具不同,CodeSmith不要求您订阅特定的应用程序设计或...
您生成应用程序时,您经常需要重复完成某些特定的任务,例如编写数据访问代码或者生成自定义集合。MyGenerate在这些时候特别有用,因为您通过对应的模板自动完成这些任务,从而不仅提高您的工作效率,而且能够自动...
codesmith 3层代码生成模板 codesmith 3层代码生成模板 codesmith 3层代码生成模板
CodeSmith 是一种语法类似于asp.net的基于模板的代码生成器,程序可以自定义模板,从而减少重复编码的劳动量,提高效率。 我现在用它是因为它可以直接生成java的存储过程类,非常方便,现在这项目使用的是存储过程+...
CodeSmith 是一种基于模板的代码生成工具,它使用类似于 ASP.NET 的语法来生成任意类型的... CodeSmith 是一种语法类似于asp.net的基于模板的代码生成器,程序可以自定义模板,从而减少重复编码的劳动量,提高效率。
CodeSmith 是一种基于模板的代码生成工具,它使用类似于 ASP.NET 的语法来生成任意类型的代码或文本。与其他许多代码生成工具不同,CodeSmith 不要求您订阅特定的应用程序设计或体系结构。使用 CodeSmith,可以生成...
当您生成应用程序时,您经常需要重复完成某些特定的任务,例如编写数据访问代码或者生成自定义集合。CodeSmith 在这些时候特别有用,因为您可以编写模板自动完成这些任务,从而不仅提高您的工作效率,而且能够自动...
当您生成应用程序时,您经常需要重复完成某些特定的任务,例如编写数据访问代码或者生成自定义集合。CodeSmith 在这些时候特别有用,因为您可以编写模板自动完成这些任务,从而不仅提高您的工作效率,而且能够自动...
codesmith代码生成器codesmith代码生成器codesmith代码生成器codesmith代码生成器codesmith代码生成器codesmith代码生成器codesmith代码生成器codesmith代码生成器codesmith代码生成器codesmith代码生成器codesmith...
最新版本的CodeSmith代码生成器下载 你可以不用到官方网站做麻烦的申请了 试用期到后,删除,然后重装即可 trial key:CS65T-WGSKL-9BKSC-XDLXK-7TSSJ-2CRDB-KABA6
当您生成应用程序时,您经常需要重复完成某些特定的任务,例如编写数据访问代码或者生成自定义集合。CodeSmith 在这些时候特别有用,因为您可以编写模板自动完成这些任务,从而不仅提高您的工作效率,而且能够自动...
最终通用三层codesmith代码生成模板,功能更加更加全面,还可以为你定制QQ:17876323
CodeSmith.v4.1.2.Pro.(代码生成工具)
1、Oledb 包括使用access数据库时三层代码的自动生成。 2、SQL 包括使用Sql Server数据库时三层代码的自动生成。 3、Procdure 包含一个根据表生成存储过程的模板 4、Model 包含一个一次生成所有Model中实体类的模板...
codesmith 代码生成器和中文帮助文档