zoukankan      html  css  js  c++  java
  • 为数据库中的表 生成类的源文件(代码生成器)

      1 using System;
      2 using System.Collections.Generic;
      3 using System.Data;
      4 using System.Data.SqlClient;
      5 using System.IO;
      6 using System.Text;
      7 
      8 namespace ModelCodeGeneratorSample
      9 {
     10     class Program
     11     {
     12         static string ConnectionString;
     13         static string NamespaceName;
     14 
     15         static Program()
     16         {
     17             //载入配置
     18             ConnectionString = "Data Source=192.168.8.119;Initial Catalog=22TopWeb;Integrated Security=False;user=EQCCD_HUNTER;password=zhey1bu2012;";
     19             NamespaceName = "Topuc22Top.Model";
     20         }
     21 
     22         static void Main(string[] args)
     23         {
     24             var content = GetTableCodeContent(ConnectionString, NamespaceName, "TB_Enterprise");
     25             if (!string.IsNullOrWhiteSpace(content)) 
     26             {
     27                 string descFileFolder = @"D:";
     28                 if (!Directory.Exists(descFileFolder))
     29                     Directory.CreateDirectory(descFileFolder);
     30                 string descFileName = "\TB_Enterprise.cs";
     31                 File.WriteAllText(descFileFolder + descFileName, content, System.Text.Encoding.UTF8);
     32             }
     33         }
     34 
     35         static string GetTableCodeContent(string conStr, string namespaceName, string tableName, string className = "")
     36             //为什么不直接用全局的 少传一个参数,曾经一个项目 的 经验
     37         {
     38             if (string.IsNullOrWhiteSpace(tableName))
     39             {
     40                 throw new ArgumentException("参数tableName不能为Empty、null或WhiteSpce");
     41             }
     42             var sb = new StringBuilder();
     43             sb.AppendFormat(@"
     44 namespace {0}
     45 {{
     46     public class {1}
     47     {{", namespaceName, (!string.IsNullOrWhiteSpace(className) ? className : tableName));
     48             var dt = GetTableFields(conStr, tableName);
     49             foreach (DataRow row in dt.Rows)
     50             {
     51                 var columnName = row["列名"];
     52                 var typeString = row["类型"];
     53                 var isNullable = row["是否为空"];
     54                 var description = row["列说明"];
     55                 sb.AppendFormat(@"
     56         /// <summary>
     57         /// {3}
     58         /// </summary>
     59         public {1}{2}  {0} {{ get; set; }}", columnName, typeString, (typeString.ToString() != "string" && isNullable.ToString() == "" ? "?" : ""), description);
     60             }
     61 
     62             sb.AppendFormat(@"
     63     }}
     64 }}
     65 ", NamespaceName);
     66 
     67             return sb.ToString();
     68         }
     69 
     70         static DataTable GetTableFields(string conStr, string tableName = "")
     71         {
     72             var sql = GetSql(tableName);
     73             var dt = ExcuteQuery(conStr, sql);
     74             return dt;
     75         }
     76 
     77         static string GetSql(string tableName = "")
     78         {
     79             var sql = @"select  
     80     [表名]=c.Name, 
     81     [表说明]=isnull(f.[value],''),  
     82     [列序号]=a.Column_id,  
     83     [列名]=a.Name,  
     84     [列说明]=isnull(e.[value],''),  
     85     [数据库类型]=b.Name,    
     86     [类型]= case when b.Name = 'image' then 'byte[]'
     87                  when b.Name in('image','uniqueidentifier','ntext','varchar','ntext','nchar','nvarchar','text','char') then 'string'
     88                  when b.Name in('tinyint','smallint','int','bigint') then 'int'
     89                  when b.Name in('date','datetime','smalldatetime') then 'DateTime'
     90                  when b.Name in('float','decimal','numeric','money','real','smallmoney') then 'decimal'
     91                  when b.Name ='bit' then 'bool' else b.name end ,
     92     [标识]= case when is_identity=1 then '是' else '' end,  
     93     [主键]= case when exists(select 1 from sys.objects x join sys.indexes y on x.Type=N'PK' and x.Name=y.Name  
     94                         join sysindexkeys z on z.ID=a.Object_id and z.indid=y.index_id and z.Colid=a.Column_id)  
     95                     then '是' else '' end,      
     96     [字节数]=case when a.[max_length]=-1 and b.Name!='xml' then 'max/2G'  
     97                   when b.Name='xml' then '2^31-1字节/2G' 
     98                   else rtrim(a.[max_length]) end,  
     99     [长度]=case when ColumnProperty(a.object_id,a.Name,'Precision')=-1 then '2^31-1' 
    100                 else rtrim(ColumnProperty(a.object_id,a.Name,'Precision')) end,  
    101     [小数位]=isnull(ColumnProperty(a.object_id,a.Name,'Scale'),0),  
    102     [是否为空]=case when a.is_nullable=1 then '是' else '' end,      
    103     [默认值]=isnull(d.text,'')      
    104 from  
    105     sys.columns a  
    106 left join 
    107     sys.types b on a.user_type_id=b.user_type_id  
    108 inner join 
    109     sys.objects c on a.object_id=c.object_id and c.Type='U' 
    110 left join 
    111     syscomments d on a.default_object_id=d.ID  
    112 left join 
    113     sys.extended_properties e on e.major_id=c.object_id and e.minor_id=a.Column_id and e.class=1   
    114 left join 
    115     sys.extended_properties f on f.major_id=c.object_id and f.minor_id=0 and f.class=1 
    116 where 1 = 1";
    117             if (!string.IsNullOrWhiteSpace(tableName))
    118             {
    119                 sql += "and c.name = '" + tableName + "'";
    120             }
    121             sql += " order by c.name, is_identity desc, a.Column_id";
    122 
    123             return sql;
    124         }
    125 
    126         static DataTable ExcuteQuery(string conStr, string cmdText, List<SqlParameter> pars = null)
    127         {
    128             using (SqlConnection conn = new SqlConnection(conStr))
    129             {
    130                 using (SqlCommand cmd = new SqlCommand(cmdText, conn))
    131                 {
    132                     if (pars != null && pars.Count > 0) cmd.Parameters.AddRange(pars.ToArray());
    133                     using (SqlDataAdapter adp = new SqlDataAdapter(cmd))
    134                     {
    135                         DataTable dt = new DataTable();
    136                         adp.Fill(dt);
    137                         return dt;
    138                     }
    139                 }
    140             }
    141         }
    142 
    143     }
    144 }

    生成的.cs文件内容

  • 相关阅读:
    【网络安全】telnet 登陆远程服务器
    【网络安全】window 快速搭建 ftp 及 多种访问方式
    科普:PCI-E插槽都有哪些样子?
    Memory及其controller芯片整体测试方案(下篇)
    Memory及其controller芯片整体测试方案(上篇)
    超通俗易懂科普:什么是光通信?
    PCB各层介绍及AD软件画PCB时的规则
    第一次接触FPGA至今,总结的宝贵经验
    嵌入式码农的10年Bug调试经验,值得一看
    做嵌入式驱动的,你一定要挺住!
  • 原文地址:https://www.cnblogs.com/frozenzhang/p/5210146.html
Copyright © 2011-2022 走看看