zoukankan      html  css  js  c++  java
  • CodeSmith 5.0工具实例篇系列2——选择数据库生成整个库的实体类。

    运行该模板时,选择需要生成的数据库,即可生成该数据库中所有表的实体类。
    申明:该系列案例已通过CodeSmith Professional 5.0.1 Revision 4983版本的测试。

    前提:运行该模板时,必须先生成 “ CodeSmith 5.0工具实例篇系列1——根据表生成单个实体类的模板”中的案例,该案例是循环数据库,将每个表当参数,传入到“CCodeSmith 5.0工具实例篇系列1——根据表生成单个实体类的模板”中执行,从而实现了整个数据库中所有表的实体类生成。

    操作说明 :运行CodeSmith Studio工具 ,创建Blank Template,并将文件名命名为:DataBaseEntityTemplate.cst。

    输入以下代码:


    <%@ CodeTemplate Language="C#" TargetLanguage="C#" Src="" Inherits="" Debug="False" LinePragmas="True" Description="根据选择的数据库生成所有表的实体类" ResponseEncoding="UTF-8" %>

    <%@ Property Name="SourceDataBase" Type="SchemaExplorer.DatabaseSchema" Default="" Optional="False" Category="" Description="" OnChanged="" Editor="" EditorBase="" Serializer="" %>

    <%@ Assembly Name="SchemaExplorer" %>
    <%@ Import Namespace="SchemaExplorer" %>

    <%
             
    //申明模板对象。
            CodeTemplate TableEntityTemplate=null;
            
    //加载需要调用的模板,并进行编译,如有错误,就将错误显示出来。
            CodeTemplateCompiler Compiler=new CodeTemplateCompiler(this.CodeTemplateInfo.DirectoryName+"TableEntityTemplate.cst");
            Compiler.Compile();
            
    if(Compiler.Errors.Count==0)
            {
                    
    //将模板实例化。
                    TableEntityTemplate=Compiler.CreateInstance();        
            }
            
    else
            {
                    
    for(int i=0;i<Compiler.Errors.Count;i++)
                    {
                            Response.WriteLine(Compiler.Errors[i].ToString());
                    }
            }
            
            
    //循环将数据库中所有的表传入到实体类生成的模板中。
            foreach(TableSchema table in SourceDataBase.Tables)
            {
                    TableEntityTemplate.SetProperty(
    "TableName",table);
                    TableEntityTemplate.Render(Response);
            }
  • 相关阅读:
    bzoj 3531 [Sdoi2014]旅行(树链剖分,线段树)
    bzoj 2243 [SDOI2011]染色(树链剖分,线段树)
    spoj 375 Query on a tree(树链剖分,线段树)
    bzoj 2618 2618: [Cqoi2006]凸多边形(半平面交)
    C++中int型与char型相互转换的问题
    408 二进制求和
    407 加一
    斐波那契数列几种算法及时间复杂度分析
    397 Longest Continuous Increasing Subsequence
    376 二叉树的路径和
  • 原文地址:https://www.cnblogs.com/juan/p/1424364.html
Copyright © 2011-2022 走看看