zoukankan      html  css  js  c++  java
  • CodeSmith 使用



     CodeSmith 以前只是听说,用了一下还不错。适合我这种每天写垃圾代码的人

    <%@ CodeTemplate Language="C#" TargetLanguage="T-SQL" Description="Create a procedure which have delete function base on a table.Must use PrimaryKey to delete a record." %>
    <%@ Assembly Name="SchemaExplorer" %>
    <%@ Import Namespace="SchemaExplorer" %>
    <%Property Name="SourceTable" Type="SchemaExplorer.TableSchema" Category="DataTable" Description="Table that the stored procedures should be based on." %>
    <%Property Name="Author" Type="String" Category="Context" Description="The author for this procedure." Optional="true"%>
    <%Property Name="Description" Type="String" Category="Context" Description="The description for this procedure." Optional="true"%>
    <script runat="template">
    public string GetSqlParameterStatement(ColumnSchema column)
    {
       string param 
    = "@" + column.Name + " " + column.NativeType;
        
    switch (column.DataType)
       {
            
    case DbType.Decimal:
           {
                param 
    += "(" + column.Precision + "" + column.Scale + ")";
              
    break;
           }
            
    default:
           {
               
    if (column.Size > 0)
                {
                   param 
    += "(" + column.Size + ")";
                }
                
    break;
            }
        }
        
    return param;
    }
    public string GetUpdateParameter()
    {   string temp
    =null;
        
    for (int i=0;i<SourceTable.Columns.Count;i++)
        { 
        
    if (!SourceTable.Columns[i].IsPrimaryKeyMember)
            { 
                temp
    =temp+SourceTable.Columns[i].Name+"=@"+SourceTable.Columns[i].Name+","+"\n";
             }
        }
        
    if (temp.Length >0)
         
    return temp.Substring (0,temp.Length-1);
        
    else
        
    return "";
        
    }
    </script>
    CREATE PROCEDURE dbo.
    <%=SourceTable.Name %>Delete
    /*
    ==================================================
    ??:
    <%= Author %>
    ??????:
    <%= System.DateTime.Now.ToShortDateString() %>
    ??:
    <%= Description %>
    ==================================================
    */
    <% for (int i = 0; i < SourceTable.PrimaryKey.MemberColumns.Count; i++) { %>
    <%= GetSqlParameterStatement(SourceTable.PrimaryKey.MemberColumns[i]) %><% if (i < SourceTable.PrimaryKey.MemberColumns.Count - 1) { %>,<% } %>    <% if (SourceTable.Columns[i].Description != "") { %>--<%= SourceTable.Columns[i].Description %><% } %>
    <% } %>
    AS
    Delete From [
    <%= SourceTable.Name %>
    Where
    <% for (int i = 0; i < SourceTable.PrimaryKey.MemberColumns.Count; i++) { %>
    <% if (i > 0) { %>AND <% } %>[<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>] = @<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>
    <% } %>



    CREATE PROCEDURE dbo.
    <%=SourceTable.Name %>SelectByID
    /*
    ==================================================
    Author:
    <%= Author %>
    CreatedTime:
    <%= System.DateTime.Now.ToShortDateString() %>
    Description:
    <%= Description %>
    ==================================================
    */
    <% for (int i = 0; i < SourceTable.PrimaryKey.MemberColumns.Count; i++) { %>
    <%= GetSqlParameterStatement(SourceTable.PrimaryKey.MemberColumns[i]) %><% if (i < SourceTable.PrimaryKey.MemberColumns.Count - 1) { %>,<% } %>    <% if (SourceTable.Columns[i].Description != "") { %>--<%= SourceTable.Columns[i].Description %><% } %>
    <% } %>

    AS
    select 
    <% for (int i = 0; i < SourceTable.Columns.Count; i++) { %>
    <%= SourceTable.Columns[i].Name %>
    <% } %>

    From [
    <%= SourceTable.Name %>
    Where
    <% for (int i = 0; i < SourceTable.PrimaryKey.MemberColumns.Count; i++) { %>
    <% if (i > 0) { %>AND <% } %>[<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>] = @<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>
    <% } %>


    CREATE PROCEDURE dbo.
    <%=SourceTable.Name %>SelectAll
    /*
    ==================================================
    Author:
    <%= Author %>
    CreatedTime:
    <%= System.DateTime.Now.ToShortDateString() %>
    Description:
    <%= Description %>
    ==================================================
    */

    AS
    select 
    <% for (int i = 0; i < SourceTable.Columns.Count; i++) { %>
    <%= SourceTable.Columns[i].Name %>
    <% } %>

    From [
    <%= SourceTable.Name %>


    CREATE PROCEDURE dbo.
    <%=SourceTable.Name %>Update
    /*
    ==================================================
    Author:
    <%= Author %>
    CreatedTime:
    <%= System.DateTime.Now.ToShortDateString() %>
    Description:
    <%= Description %>
    ==================================================
    */
    <% for (int i = 0; i < SourceTable.Columns.Count; i++) { %>
    <%= GetSqlParameterStatement(SourceTable.Columns[i]) %>
    <% } %>
    AS
    Update  [
    <%= SourceTable.Name %>]  set 

    <%=GetUpdateParameter()%>
    Where
    <% for (int i = 0; i < SourceTable.PrimaryKey.MemberColumns.Count; i++) { %>
    <% if (i > 0) { %>AND <% } %>[<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>] = @<%= SourceTable.PrimaryKey.MemberColumns[i].Name %>
    <% } %>



  • 相关阅读:
    Java代码输出是“father”还是“child”(二)
    Java代码输出是“father”还是“child”(一)
    “var arr = []; ”和 “var arr = {};” 的区别
    Servlet页面间对象传递的方法
    利用OWI优化SQL
    Oracle 12c 12.1.0.1.0管理控制文件官方文档说明
    计算工资
    检测本地网络连接状态断开以及恢复的方法
    linux 批量创建用户
    比较两表数据
  • 原文地址:https://www.cnblogs.com/gwazy/p/832598.html
Copyright © 2011-2022 走看看