• codesmith使用


    安装后

    破解

    将两个dll烤到安装目录下!

     自己制作CodeTemplateRule

    将CodeSmith.Engine(在bin目录里)和SchemaExplorer(在AddIns目录里)  两个类添加到引用

    using System;
    using System.Text;
    using System.ComponentModel;
    using CodeSmith.Engine;
    using System.Data;
    using SchemaExplorer;

    namespace CodeTemplateRule
    {
        
    /**/
        
    /// <summary>
        
    /// CodeSmith自动生成代码所用到的函数
        
    /// </summary>
        public class CodeTemplateRule
        {
            
    /**/
            
    /// <summary>
            
    /// 获取所有列的集合
            
    /// </summary>
            
    /// <param name="dataBase">数据库Schema</param>
            
    /// <param name="tableName">表名</param>
            
    /// <returns>Columns Schema</returns>
            public ColumnSchemaCollection GetColumnCollection(DatabaseSchema dataBase, string tableName)
            {
                TableSchemaCollection tables 
    = new TableSchemaCollection(dataBase.Tables);
                ColumnSchemaCollection columns 
    = null;
                
    for (int i = 0; i < tables.Count; i++)
                {
                    
    if (tables[i].Name.ToUpper() == tableName.ToUpper())
                    {
                        TableSchema ts 
    = tables[i];
                        columns 
    = new ColumnSchemaCollection(ts.Columns);
                    }
                }
                
    return columns;
            }

            
    /**/
            
    /// <summary>
            
    /// 获取处理后的表名 例如:ORG_Person,返回Person
            
    /// </summary>
            
    /// <param name="tableName">表名</param>
            
    /// <returns>返回处理后的表名</returns>
            public string GetTableName(string tableName)
            {
                
    int i = tableName.IndexOf("_");
                
    return tableName.Substring(i + 1, tableName.Length - (i + 1));
            }

            
    /**/
            
    /// <summary>
            
    /// 获取唯一号的变量名,第一个字母小写
            
    /// </summary>
            
    /// <param name="guidColumn">唯一号列名</param>
            
    /// <returns>唯一号的变量名</returns>
            public string GetGuidColumnVar(string guidColumn)
            {
                
    string guid;
                guid 
    = guidColumn.Substring(01).ToLower() + guidColumn.Substring(1, guidColumn.Length - 1);
                
    return guid;
            }

            
    /**/
            
    /// <summary>
            
    /// 获取c#变量类型
            
    /// </summary>
            
    /// <param name="column"></param>
            
    /// <returns>c#变量类型</returns>
            public string GetType(ColumnSchema column)
            {
                
    if (column.Name.EndsWith("TypeCode")) return column.Name;

                
    switch (column.DataType)
                {
                    
    case DbType.AnsiString: return "string";
                    
    case DbType.AnsiStringFixedLength: return "string";
                    
    case DbType.Binary: return "byte[]";
                    
    case DbType.Boolean: return "bool";
                    
    case DbType.Byte: return "int";
                    
    case DbType.Currency: return "decimal";
                    
    case DbType.Date: return "DateTime";
                    
    case DbType.DateTime: return "DateTime";
                    
    case DbType.Decimal: return "decimal";
                    
    case DbType.Double: return "double";
                    
    case DbType.Guid: return "Guid";
                    
    case DbType.Int16: return "short";
                    
    case DbType.Int32: return "int";
                    
    case DbType.Int64: return "long";
                    
    case DbType.Object: return "object";
                    
    case DbType.SByte: return "sbyte";
                    
    case DbType.Single: return "float";
                    
    case DbType.String: return "string";
                    
    case DbType.StringFixedLength: return "string";
                    
    case DbType.Time: return "TimeSpan";
                    
    case DbType.UInt16: return "ushort";
                    
    case DbType.UInt32: return "uint";
                    
    case DbType.UInt64: return "ulong";
                    
    case DbType.VarNumeric: return "decimal";
                    
    default:
                        {
                            
    return "__UNKNOWN__" + column.NativeType;
                        }
                }
            }

            
    /**/
            
    /// <summary>
            
    /// 获取c#变量类型默认值
            
    /// </summary>
            
    /// <param name="column"></param>
            
    /// <returns>c#变量类型默认值</returns>
            public string GetDefaultValue(ColumnSchema column)
            {
                
    if (column.Name.EndsWith("TypeCode")) return column.Name;

                
    switch (column.DataType)
                {
                    
    case DbType.AnsiString: return "\"\"";
                    
    case DbType.AnsiStringFixedLength: return "\"\"";
                    
    case DbType.Binary: return "null";
                    
    case DbType.Boolean: return "false";
                    
    case DbType.Byte: return "0";
                    
    case DbType.Currency: return "0";
                    
    case DbType.Date: return "DateTime.Parse(\"1900-1-1\")";
                    
    case DbType.DateTime: return "DateTime.Parse(\"1900-1-1\")";
                    
    case DbType.Decimal: return "0";
                    
    case DbType.Double: return "0";
                    
    case DbType.Guid: return "Guid.NewGuid().ToString()";
                    
    case DbType.Int16: return "0";
                    
    case DbType.Int32: return "0";
                    
    case DbType.Int64: return "0";
                    
    case DbType.Object: return "\"\"";
                    
    case DbType.SByte: return "0";
                    
    case DbType.Single: return "0";
                    
    case DbType.String: return "\"\"";
                    
    case DbType.StringFixedLength: return "";
                    
    case DbType.Time: return "DateTime.Parse(\"1900-1-1\")";
                    
    case DbType.UInt16: return "0";
                    
    case DbType.UInt32: return "0";
                    
    case DbType.UInt64: return "0";
                    
    case DbType.VarNumeric: return "0";
                    
    default:
                        {
                            
    return "__UNKNOWN__" + column.NativeType;
                        }
                }
            }

            
    /**/
            
    /// <summary>
            
    /// 获取c#变量类型默认值
            
    /// </summary>
            
    /// <param name="column"></param>
            
    /// <returns>c#变量类型默认值</returns>
            public string GetConvert(ColumnSchema column)
            {
                
    if (column.Name.EndsWith("TypeCode")) return column.Name;

                
    switch (column.DataType)
                {
                    
    case DbType.AnsiString: return "Convert.ToString";
                    
    case DbType.AnsiStringFixedLength: return "Convert.ToString";
                    
    case DbType.Binary: return "Convert.ToByte";
                    
    case DbType.Boolean: return "Convert.ToBoolean";
                    
    case DbType.Byte: return "Convert.ToInt32";
                    
    case DbType.Currency: return "Convert.ToDecimal";
                    
    case DbType.Date: return "Convert.DateTime";
                    
    case DbType.DateTime: return "Convert.DateTime";
                    
    case DbType.Decimal: return "Convert.ToDecimal";
                    
    case DbType.Double: return "Convert.ToDouble";
                    
    case DbType.Guid: return "Convert.ToString";
                    
    case DbType.Int16: return "Convert.ToInt16";
                    
    case DbType.Int32: return "Convert.ToInt32";
                    
    case DbType.Int64: return "Convert.ToInt64";
                    
    case DbType.Object: return "Convert.ToString";
                    
    case DbType.SByte: return "Convert.ToByte";
                    
    case DbType.Single: return "Convert.ToInt32";
                    
    case DbType.String: return "Convert.ToString";
                    
    case DbType.StringFixedLength: return "Convert.ToString";
                    
    case DbType.Time: return "Convert.DateTime";
                    
    case DbType.UInt16: return "Convert.ToUInt16";
                    
    case DbType.UInt32: return "Convert.ToUInt32";
                    
    case DbType.UInt64: return "Convert.ToUInt64";
                    
    case DbType.VarNumeric: return "Convert.ToDecimal";
                    
    default:
                        {
                            
    return "__UNKNOWN__" + column.NativeType;
                        }
                }
            }
        }
    }

    将 重新编译生成的CodeTemplateRule拷贝到 codesmith目录下的 两个文件夹中

    模板页中添加引用

    Code
  • 相关阅读:
    与非
    抄卡组
    数据结构》关于差分约束的两三事(BZOJ2330)
    刷题向》图论》BZOJ1179 关于tarjan和SPFA的15秒(normal)
    图论算法》关于tarjan算法两三事
    图论算法》关于SPFA和Dijkstra算法的两三事
    刷题向》DP》值得一做》关于对DP问题的充分考虑(normal)
    数据结构》关于线段树两三事(新手向)(工具向)
    图论算法》关于匈牙利算法的两三事
    关于羊和车的问题
  • 原文地址:https://www.cnblogs.com/aaa6818162/p/1448249.html
Copyright © 2020-2023  润新知