CodeSmith基础(二)
<!-- <rdf:RDF xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:trackback="http://madskills.com/public/xml/rss/module/trackback/"> <rdf:Description rdf:about="http://www.cnblogs.com/Bear-Study-Hard/archive/2005/12/19/300142.html" dc:identifier="http://www.cnblogs.com/Bear-Study-Hard/archive/2005/12/19/300142.html" dc:title="CodeSmith基础(二)" trackback:ping="http://www.cnblogs.com/Bear-Study-Hard/services/trackbacks/300142.aspx" /> </rdf:RDF> --> 本文将介绍CodeSmith与数据库进行交互生成相应的存储过程,本例使用的数据库为SQL Server 2000。
在与数据库进行交互时,我们使用到了一个CodeSmith自带的组件SchemaExplorer,利用这个组件我们可以访问数据库的数据表、存储过程、视图等,并可以得到相应的数据类型、标识列、列的(字段)名称等信息。
下面这个例子是教我们如何生成一个存储过程,虽然网上有很多一样的例子,但是我是从CodeSmith中的英文帮助中自己翻译出来的:)
使用的是SQL Server 2000自带的Northwind数据库,生成一个关于Orders订单表的更新存储过程。
第一步还是指明模板使用的语言和生成的目标语言。
第二步就是我们要加载使用访问数据库的组件SchemaExplorer,并声明其使用的命名空间。
因为是针对表去生成存储过程,则首先要定义一个存储表名称使用的变量,然后指明这个变量类型为数据库中的表,这样我们可以通过这个数据表类型的变量得到相应的表的信息。
如果想访问视图的话,则将变量类型Type中的SchemaExplorer.TableSchema修改为SchemaExplorer.ViewSchema即可。
得到表名的方法
下面利用循环语句遍历表的各个列,拼出存储过程需要传递的参数。
调用的GetSqlParameterStatement方法是用来生成参数的字符串,例如生成“@CustomerID nchar(5)”,后边紧跟的if判断是用来生成参数之间相隔使用的逗号的。
生成参数字符串的方法,参数为SchemaExplorer.ColumnSchema列类型
下面来生成需要更新的字段,更新时仅能更新非主键字段的值,在SchemaExplorer中支持这种区别,使用SourceTable.NonPrimaryKeyColumns即可得到非主键字段的集合。
以下为整体的代码结构
在与数据库进行交互时,我们使用到了一个CodeSmith自带的组件SchemaExplorer,利用这个组件我们可以访问数据库的数据表、存储过程、视图等,并可以得到相应的数据类型、标识列、列的(字段)名称等信息。
下面这个例子是教我们如何生成一个存储过程,虽然网上有很多一样的例子,但是我是从CodeSmith中的英文帮助中自己翻译出来的:)
使用的是SQL Server 2000自带的Northwind数据库,生成一个关于Orders订单表的更新存储过程。
第一步还是指明模板使用的语言和生成的目标语言。
<%@CodeTemplateLanguage="C#"TargetLanguage="T-SQL"Description="Generatesaupdatestoredprocedure."%>
第二步就是我们要加载使用访问数据库的组件SchemaExplorer,并声明其使用的命名空间。
<%@AssemblyName="SchemaExplorer"%>
<%@ImportNamespace="SchemaExplorer"%>
<%@ImportNamespace="SchemaExplorer"%>
因为是针对表去生成存储过程,则首先要定义一个存储表名称使用的变量,然后指明这个变量类型为数据库中的表,这样我们可以通过这个数据表类型的变量得到相应的表的信息。
<%@PropertyName="SourceTable"Type="SchemaExplorer.TableSchema"Category="Context"Description="Tablethatthestoredproceduresshouldbebasedon."%>
如果想访问视图的话,则将变量类型Type中的SchemaExplorer.TableSchema修改为SchemaExplorer.ViewSchema即可。
得到表名的方法
CREATEPROCEDUREdbo.Update<%=SourceTable.Name%>
下面利用循环语句遍历表的各个列,拼出存储过程需要传递的参数。
<%for(inti=0;i<SourceTable.Columns.Count;i++){%>
<%=GetSqlParameterStatement(SourceTable.Columns[i])%><%if(i<SourceTable.Columns.Count-1){%>,<%}%>
<%}%>
<%=GetSqlParameterStatement(SourceTable.Columns[i])%><%if(i<SourceTable.Columns.Count-1){%>,<%}%>
<%}%>
调用的GetSqlParameterStatement方法是用来生成参数的字符串,例如生成“@CustomerID nchar(5)”,后边紧跟的if判断是用来生成参数之间相隔使用的逗号的。
生成参数字符串的方法,参数为SchemaExplorer.ColumnSchema列类型
1<scriptrunat="template">
2publicstringGetSqlParameterStatement(ColumnSchemacolumn)
3{
4stringparam="@"+column.Name+""+column.NativeType;
5
6switch(column.DataType)
7{
8caseDbType.Decimal:
9{
10param+="("+column.Precision+","+column.Scale+")";
11break;
12}
13default:
14{
15if(column.Size>0)
16{
17param+="("+column.Size+")";
18}
19break;
20}
21}
22
23returnparam;
24}
25</script>
2publicstringGetSqlParameterStatement(ColumnSchemacolumn)
3{
4stringparam="@"+column.Name+""+column.NativeType;
5
6switch(column.DataType)
7{
8caseDbType.Decimal:
9{
10param+="("+column.Precision+","+column.Scale+")";
11break;
12}
13default:
14{
15if(column.Size>0)
16{
17param+="("+column.Size+")";
18}
19break;
20}
21}
22
23returnparam;
24}
25</script>
下面来生成需要更新的字段,更新时仅能更新非主键字段的值,在SchemaExplorer中支持这种区别,使用SourceTable.NonPrimaryKeyColumns即可得到非主键字段的集合。
1UPDATE[<%=SourceTable.Name%>]SET
2<%for(inti=0;i<SourceTable.NonPrimaryKeyColumns.Count;i++){%>
3[<%=SourceTable.NonPrimaryKeyColumns[i].Name%>]=@<%=SourceTable.NonPrimaryKeyColumns[i].Name%><%if(i<SourceTable.NonPrimaryKeyColumns.Count-1){%>,<%}%>
4<%}%>
2<%for(inti=0;i<SourceTable.NonPrimaryKeyColumns.Count;i++){%>
3[<%=SourceTable.NonPrimaryKeyColumns[i].Name%>]=@<%=SourceTable.NonPrimaryKeyColumns[i].Name%><%if(i<SourceTable.NonPrimaryKeyColumns.Count-1){%>,<%}%>
4<%}%>
然后再使用SourceTable.PrimaryKey.MemberColumns得到数据表中的主键集合,生成更新条件
1WHERE
2<%for(inti=0;i<SourceTable.PrimaryKey.MemberColumns.Count;i++){%>
3<%if(i>0){%>AND<%}%>
4[<%=SourceTable.PrimaryKey.MemberColumns[i].Name%>]=@<%=SourceTable.PrimaryKey.MemberColumns[i].Name%>
5<%}%>
2<%for(inti=0;i<SourceTable.PrimaryKey.MemberColumns.Count;i++){%>
3<%if(i>0){%>AND<%}%>
4[<%=SourceTable.PrimaryKey.MemberColumns[i].Name%>]=@<%=SourceTable.PrimaryKey.MemberColumns[i].Name%>
5<%}%>
以下为整体的代码结构
1<%@CodeTemplateLanguage="C#"TargetLanguage="T-SQL"
2Description="Generatesaupdatestoredprocedure."%>
3
4<%@PropertyName="SourceTable"Type="SchemaExplorer.TableSchema"
5Category="Context"
6Description="Tablethatthestoredproceduresshouldbebasedon."%>
7
8<%@AssemblyName="SchemaExplorer"%>
9
10<%@ImportNamespace="SchemaExplorer"%>
11
12<scriptrunat="template">
13publicstringGetSqlParameterStatement(ColumnSchemacolumn)
14{
15stringparam="@"+column.Name+""+column.NativeType;
16
17switch(column.DataType)
18{
19caseDbType.Decimal:
20{
21param+="("+column.Precision+","+column.Scale+")";
22break;
23}
24default:
25{
26if(column.Size>0)
27{
28param+="("+column.Size+")";
29}
30break;
31}
32}
33
34returnparam;
35}
36</script>
37
38-----------------------------------------------------------------
39--DateCreated:<%=DateTime.Now.ToLongDateString()%>
40--CreatedBy:GeneratedbyCodeSmith
41-----------------------------------------------------------------
42
43CREATEPROCEDUREdbo.Update<%=SourceTable.Name%>
44<%for(inti=0;i<SourceTable.Columns.Count;i++){%>
45<%=GetSqlParameterStatement(SourceTable.Columns[i])%><%if(i<SourceTable.Columns.Count-1){%>,<%}%>
46<%}%>
47AS
48
49UPDATE[<%=SourceTable.Name%>]SET
50<%for(inti=0;i<SourceTable.NonPrimaryKeyColumns.Count;i++){%>
51[<%=SourceTable.NonPrimaryKeyColumns[i].Name%>]=@<%=SourceTable.NonPrimaryKeyColumns[i].Name%><%if(i<SourceTable.NonPrimaryKeyColumns.Count-1){%>,<%}%>
52<%}%>
53WHERE
54<%for(inti=0;i<SourceTable.PrimaryKey.MemberColumns.Count;i++){%>
55<%if(i>0){%>AND<%}%>
56[<%=SourceTable.PrimaryKey.MemberColumns[i].Name%>]=@<%=SourceTable.PrimaryKey.MemberColumns[i].Name%>
57<%}%>
58
2Description="Generatesaupdatestoredprocedure."%>
3
4<%@PropertyName="SourceTable"Type="SchemaExplorer.TableSchema"
5Category="Context"
6Description="Tablethatthestoredproceduresshouldbebasedon."%>
7
8<%@AssemblyName="SchemaExplorer"%>
9
10<%@ImportNamespace="SchemaExplorer"%>
11
12<scriptrunat="template">
13publicstringGetSqlParameterStatement(ColumnSchemacolumn)
14{
15stringparam="@"+column.Name+""+column.NativeType;
16
17switch(column.DataType)
18{
19caseDbType.Decimal:
20{
21param+="("+column.Precision+","+column.Scale+")";
22break;
23}
24default:
25{
26if(column.Size>0)
27{
28param+="("+column.Size+")";
29}
30break;
31}
32}
33
34returnparam;
35}
36</script>
37
38-----------------------------------------------------------------
39--DateCreated:<%=DateTime.Now.ToLongDateString()%>
40--CreatedBy:GeneratedbyCodeSmith
41-----------------------------------------------------------------
42
43CREATEPROCEDUREdbo.Update<%=SourceTable.Name%>
44<%for(inti=0;i<SourceTable.Columns.Count;i++){%>
45<%=GetSqlParameterStatement(SourceTable.Columns[i])%><%if(i<SourceTable.Columns.Count-1){%>,<%}%>
46<%}%>
47AS
48
49UPDATE[<%=SourceTable.Name%>]SET
50<%for(inti=0;i<SourceTable.NonPrimaryKeyColumns.Count;i++){%>
51[<%=SourceTable.NonPrimaryKeyColumns[i].Name%>]=@<%=SourceTable.NonPrimaryKeyColumns[i].Name%><%if(i<SourceTable.NonPrimaryKeyColumns.Count-1){%>,<%}%>
52<%}%>
53WHERE
54<%for(inti=0;i<SourceTable.PrimaryKey.MemberColumns.Count;i++){%>
55<%if(i>0){%>AND<%}%>
56[<%=SourceTable.PrimaryKey.MemberColumns[i].Name%>]=@<%=SourceTable.PrimaryKey.MemberColumns[i].Name%>
57<%}%>
58
相关推荐
总的来说,这个CodeSmith基础教程系列旨在全面介绍CodeSmith的使用,无论你是初学者还是有一定经验的开发者,都能从中受益。通过学习和实践,你将能够利用CodeSmith提高开发效率,减少重复编码的工作,专注于更高...
二、CodeSmith的核心功能 1. 模板语言:CodeSmith使用一种称为“CSharpScript”的模板语言,它结合了C#的语法和特殊的模板指令。例如,`<# #>`用于包围代码块,`<#= #>`用于插入表达式的结果。 2. 数据源集成:...
一、CodeSmith基础 1. 安装与配置:首先,我们需要了解如何下载并安装CodeSmith,以及如何配置其工作环境,包括.NET Framework版本要求和关联数据库驱动。 2. 模板语言:CodeSmith使用一种名为CSTL(CodeSmith ...
### CodeSmith基础教程详解 #### 一、CodeSmith简介与应用背景 CodeSmith是一款强大的代码生成工具,主要用于根据模板自动生成各种.NET平台上的代码。它能够显著提高开发效率,减少手动编写重复性代码的工作量。本...
总结来说,"CodeSmith模板集合C#版"是一个强大的工具,它通过预定义的模板简化了C#开发中的对象持久化和数据库事务处理,使得开发者可以更专注于业务逻辑的实现,而不是基础代码的编写。对于大型项目或者团队开发,...
2. 数据库元数据获取:获取数据库表、视图、索引、约束等对象的信息,为代码生成提供基础数据。 3. SQL查询支持:支持PostgreSQL特定的SQL语法,以便在生成代码时创建合适的数据库操作语句。 4. 表和视图的映射:将...
此外,还需要具备一定的CodeSmith和NHibernate基础知识。 #### 三、具体步骤 ##### 3.1 打开CodeSmith并选择模板 首先启动CodeSmith工具,然后通过“文件”菜单中的“新建”选项来创建一个新的项目。在弹出的新建...
《codesmith 3层代码生成模板详解》 Codesmith,作为一个强大的代码生成工具,深受广大开发者喜爱...通过熟练掌握和运用这些模板,可以显著提升开发效率,降低维护成本,使开发者更专注于业务创新而非基础代码的编写。
#### 二、CodeSmith的基本使用 1. **创建模板** - 在创建模板时,首先需要指定这是一个针对哪种编程语言的模板。例如,如果要生成C#代码,则需要这样设置: ```xml CodeTemplate Language="C#" ...
一、CodeSmith基础入门 1. **安装与配置**:首先介绍如何下载并安装CodeSmith,包括注册码的获取和激活过程。同时,讲解如何配置CodeSmith的模板路径,以便后续使用自定义模板。 2. **模板语言基础**:CodeSmith...
### 二、CodeSmith模板基础 在所提供的部分代码中,我们可以看到模板文件的基本结构: ```vb ``` 这段元数据定义了模板的基础属性,例如使用的脚本语言是VB.NET (`CodeTemplateLanguage="VB"`), 生成的目标语言...
二、codesmith的核心功能 1. **模板引擎**:codesmith的强大力量在于其内置的模板引擎。这个引擎允许开发者使用一种类似于HTML的标记语言(例如:Velocity或NVelocity)来编写模板,模板中可以包含动态逻辑,这样当...
知识点一:CodeSmith基础概念和功能 CodeSmith是一个代码生成框架,它提供了一种机制,允许通过模板引擎和代码生成器来生成应用程序代码和数据库访问层代码。CodeSmith的核心功能包括: - 代码生成:能够根据预先...
压缩包中的模板文件是 Codesmith 社区共享的宝贵资源,包括基础模板、通用模板以及特定场景下的定制模板。这些模板可以直接用于项目中,也可以作为参考,帮助开发者快速构建自己的模板库。 五、最佳实践 在实际使用...
#### 二、CodeSmith资源汇总 根据提供的描述及部分链接,我们可以对CodeSmith相关的资源进行整理: 1. **CodeSmith Templates Share论坛**:这是一个专门用于分享CodeSmith模板的论坛(地址:...
1. 理解模板语法:codesmith 使用其特有的模板语言,学习并熟练掌握其语法是创建和修改模板的基础。 2. 定义变量和宏:模板中的变量和宏可以动态地替换为实际值,根据输入参数生成个性化代码。 3. 结构化设计:模板...
一、基础概念与用途 Codesmith的核心功能是通过模板引擎将数据库结构转换为各种编程语言的代码,如C#、Java等。它通过读取数据库的元数据,自动生成诸如实体类、数据访问层、业务逻辑层以及控制层等代码,减少了...
二、Codesmith的功能特点 1. **代码自动生成**:无论是简单的CRUD操作,还是复杂的业务逻辑,Codesmith都能根据模板快速生成。例如,它可以基于数据库表结构自动创建数据访问层(DAL)、业务逻辑层(BLL)以及视图...
codesmith nhibernate模板虽然能快速生成基础代码,但可能无法满足所有特定需求。开发者可以通过修改模板文件,定制更复杂的逻辑,例如添加验证规则、事务处理、缓存策略等。此外,还可以考虑与自动化构建工具(如...