zoukankan      html  css  js  c++  java
  • CodeSmith6.5 Add

    <%@ CodeTemplate Language="C#" TargetLanguage="C#" Debug="False" Description="Template description here." %>
    <%@ Property Name="SourceTable" Type="SchemaExplorer.TableSchema"  Category="Context"  Optional="True" Description="the table name"   %>
    <%@ Assembly Name="SchemaExplorer" %>
    <%@ Import Namespace="SchemaExplorer" %>
    <%@ Assembly Name="CodeSmith.BaseTemplates" %>
    <%@ Import Namespace="CodeSmith.BaseTemplates" %>
    <%@ Assembly Name="CodeSmith.CustomProperties" %>
    <%@ Import Namespace="CodeSmith.CustomProperties" %>
    <%@ Property Name="ConnectionTypeName" Type="ConnectionType" Category="数据源连接类型" %>
    
    <script runat="template">
    public enum ConnectionType
    {
        SqlHelper,
        MySqlHelper,
        OleDbHelper
    }
    public string GetParameterTypeName()
    {
        switch(ConnectionTypeName)
        {
            case ConnectionType.SqlHelper:return "SqlParameter";
            case ConnectionType.MySqlHelper:return "MySqlParameter";
            case ConnectionType.OleDbHelper:return "OleDbParameter";
            default:return "SqlParameter";
        }
    }
    </script>
    public bool Add(Model.<%=this.SourceTable.Name.Substring(0,1).ToUpper() %><%=this.SourceTable.Name.Substring(1) %>Model model)
    {
        StringBuilder commandText=new StringBuilder();
        commandText.Append("insert into <%=this.SourceTable.Name %>(");
        <%  string cols=string.Empty;
            string paramNames=string.Empty;
            foreach(ColumnSchema col in this.SourceTable.Columns)
            {
                cols+=col.Name+",";
                paramNames+="@"+col.Name+",";
            }
            cols=cols.Remove(cols.Length-1);
            paramNames=paramNames.Remove(paramNames.Length-1);
        %>
        commandText.Append("<%=cols %>)");
        commandText.Append(" values (");
        commandText.Append("<%=paramNames %>)");
        <%=GetParameterTypeName() %>[] commandParameters = {
                <%
                string[] strParamNames=cols.Split(',');
                for(int i=0;i<strParamNames.Length-1;i++)
                {%>
                new <%=GetParameterTypeName() %>("@<%=strParamNames[i] %>", model.<%=strParamNames[i].Substring(0,1).ToUpper() %><%=strParamNames[i].Substring(1) %>),
                <%}%>
                new <%=GetParameterTypeName() %>("@<%=strParamNames[strParamNames.Length-1] %>", model.<%=strParamNames[strParamNames.Length-1].Substring(0,1).ToUpper() %><%=strParamNames[strParamNames.Length-1].Substring(1) %>)
                };
    
        int rows=DBUtility.<%=ConnectionTypeName %>.ExecuteNonQuery(commandText.ToString(),commandParameters);
        if (rows > 0)
        {
            return true;
        }
        else
        {
            return false;
        }
    }
  • 相关阅读:
    PAT 1006 Sign In and Sign Out
    PAT 1004. Counting Leaves
    JavaEE开发环境安装
    NoSql数据库探讨
    maven的配置
    VMWARE 下使用 32位 Ubuntu Linux ,不能给它分配超过3.5G 内存?
    XCODE 4.3 WITH NO GCC?
    在苹果虚拟机上跑 ROR —— Ruby on Rails On Vmware OSX 10.7.3
    推荐一首让人疯狂的好歌《Pumped Up Kicks》。好吧,顺便测下博客园可以写点无关技术的帖子吗?
    RUBY元编程学习之”编写你的第一种领域专属语言“
  • 原文地址:https://www.cnblogs.com/xinzheng/p/4488162.html
Copyright © 2011-2022 走看看