// 获取到所有的用户表.
DataTable userTableName = GetTable( "select name as tablename from sysobjects where xtype = 'U'" );

//根据表名获取所有字段和字段类型
            DataTable myTable = 
                GetTable( 
                    "select syscolumns.name,systypes.name as type from syscolumns  " + 
                    " INNER   JOIN  sysobjects  ON   syscolumns.id  =  sysobjects.id " + 
                    "INNER   JOIN   systypes   ON   syscolumns.xtype   =   systypes.xtype " + 
                    " WHERE   (sysobjects.name   =   '" + tableName + "')   AND   (systypes.name   <>   'sysname') ");

//创建一个新的表.需要生成的数据
//字段1:修饰符 - 一般为 private 
//字段2:修饰符2 - 一般我不写.可以写 statice
//字段3:SQL字段的类型 - 在生成.cs文件前会转换成c#类型
//字段4:生成属性名称 - 与表内字段名一样
            DataTableNew.Columns.Add("xiushifu1", typeof (string)); 
            DataTableNew.Columns.Add("xiushifu2", typeof (string)); 
            DataTableNew.Columns.Add("type", typeof (string)); 
            DataTableNew.Columns.Add("name", typeof (string));

// 进行类型转换
//为生成实体需要的数据添加记录保存
            for (int i = 0; i < myTable.Rows.Count; i++) 
            { 
                string typeName = ChangeToCSharpType(myTable.Rows["type"].ToString());

DataTableNew.Rows.Add(new object[] {"private", "", typeName, myTable.Rows["name"]}); 
            }

//进行类型转换函数
        protected static string ChangeToCSharpType( string type ) 
        { 
            string reval;

switch( type.ToLower() ) 
            { 
                case "int": 
                    reval = "Int32"; 
                    break; 
                case "text": 
                    reval = "String"; 
                    break; 
                case "bigint": 
                    reval = "Int64"; 
                    break; 
                case "binary": 
                    reval = "System.Byte[]"; 
                    break; 
                case "bit": 
                    reval = "Boolean"; 
                    break; 
                case "char": 
                    reval = "String"; 
                    break; 
                case "datetime": 
                    reval = "System.DateTime"; 
                    break; 
                case "decimal": 
                    reval = "System.Decimal"; 
                    break; 
                case "float": 
                    reval = "System.Double"; 
                    break; 
                case "image": 
                    reval = "System.Byte[]"; 
                    break; 
                case "money": 
                    reval = "System.Decimal"; 
                    break; 
                case "nchar": 
                    reval = "String"; 
                    break; 
                case "ntext": 
                    reval = "String"; 
                    break; 
                case "numeric": 
                    reval = "System.Decimal"; 
                    break; 
                case "nvarchar": 
                    reval = "String"; 
                    break; 
                case "real": 
                    reval = "System.Single"; 
                    break; 
                case "smalldatetime": 
                    reval = "System.DateTime"; 
                    break; 
                case "smallint": 
                    reval = "Int16"; 
                    break; 
                case "smallmoney": 
                    reval = "System.Decimal"; 
                    break; 
                case "timestamp": 
                    reval = "System.DateTime"; 
                    break; 
                case "tinyint": 
                    reval = "System.Byte"; 
                    break; 
                case "uniqueidentifier": 
                    reval = "System.Guid"; 
                    break; 
                case "varbinary": 
                    reval = "System.Byte[]"; 
                    break; 
                case "varchar": 
                    reval = "String"; 
                    break; 
                case "Variant": 
                    reval = "Object"; 
                    break; 
                default: 
                    reval = "String"; 
                    break; 
            } 
            return reval; 
        }

//创建文本流并设置编码
TextWriter writer = new StreamWriter( 
                      new BufferedStream( 
                      new FileStream( fileDesc , FileMode.Create , FileAccess.Write ) ) , System.Text.Encoding.GetEncoding( "gb2312" ) )

// 写入命名空间和类名
                writer.WriteLine( "using System;" ); 
                writer.WriteLine();

writer.WriteLine( "namespace " + nameSpace ); 
                writer.WriteLine( "{" ); 
                writer.WriteLine( "\tpublic class " + className ); 
                writer.WriteLine( "\t{" );

//写入所有私有变量
                for( int i = 0 ; i < table.Rows.Count ; i++ ) 
                { 
                    object [ ] row = table.Rows [ i ].ItemArray; 
                    writer.Write( "\t\t" ); 
                    for( int j = 0 ; j < row.Length ; j++ ) 
                    { 
                        writer.Write( row [ j ].Equals( "无" ) ? "" : row [ j ] + ( j == row.Length - 1 ? "" : " " ) ); 
                    } 
                    writer.Write( ";" ); 
                    writer.WriteLine(); 
                }

//写入所有属性
                for( int i = 0 ; i < table.Rows.Count ; i++ ) 
                { 
                    writer.Write( "\t\t" ); 
                    writer.Write( "public " ); 
                    object [ ] row = table.Rows [ i ].ItemArray; 
                    for( int j = 1 ; j < row.Length - 1 ; j++ ) 
                    { 
                        if( row [ j ].Equals( "static" ) ) 
                        { 
                            writer.Write( "static " ); 
                            continue; 
                        } 
                        writer.Write( row [ j ].Equals( "无" ) ? "" : row [ j ] + " " ); 
                    } 
                    string attribName = row [ row.Length - 1 ].ToString(); 
                    writer.Write( attribName.Substring( 0 , 1 ).ToUpper() + attribName.Substring( 1 , attribName.Length - 1 ) ); 
                    writer.WriteLine(); 
                    writer.WriteLine( "\t\t{" ); 
                    writer.WriteLine( "\t\t\tget" ); 
                    writer.WriteLine( "\t\t\t{" ); 
                    if( row [ 1 ].Equals( "static" ) ) 
                    { 
                        writer.WriteLine( "\t\t\t\treturn " + attribName + ";" ); 
                    } 
                    else 
                    { 
                        writer.WriteLine( "\t\t\t\treturn this." + attribName + ";" ); 
                    } 
                    writer.WriteLine( "\t\t\t}" ); 
                    writer.WriteLine( "\t\t\tset" ); 
                    writer.WriteLine( "\t\t\t{" ); 
                    if( row [ 1 ].Equals( "static" ) ) 
                    { 
                        writer.WriteLine( "\t\t\t\t" + attribName + " = value;" ); 
                    } 
                    else 
                    { 
                        writer.WriteLine( "\t\t\t\tthis." + attribName + "= value;" ); 
                    } 
                    writer.WriteLine( "\t\t\t}" ); 
                    writer.WriteLine( "\t\t}" ); 
                } 
                writer.WriteLine( "\t}" ); 
                writer.WriteLine( "}" );

.net自动生成数据库表的类的更多相关文章

  1. Mybatis总结之如何自动生成数据库表结构

    一般情况下,用Mybatis的时候是先设计表结构再进行实体类以及映射文件编写的,特别是用代码生成器的时候. 但有时候不想用代码生成器,也不想定义表结构,那怎么办? 这个时候就会想到Hibernate, ...

  2. 【工具篇】利用DBExportDoc V1.0 For MySQL自动生成数据库表结构文档

    对于DBA或开发来说,如何规范化你的数据库表结构文档是灰常之重要的一件事情.但是当你的库,你的表排山倒海滴多的时候,你就会很头疼了. 推荐一款工具DBExportDoc V1.0 For MySQL( ...

  3. Intellij IDEA集成mybatis-generator插件自动生成数据库实体操作类

    Intellij IDEA集成mybatis-generator插件自动生成数据库实体操作类 转载至:https://blog.csdn.net/fishinhouse/article/details ...

  4. NetCore使用使用Scaffold-DbContext命令生成数据库表实体类

    一.为了模拟项目,本处创建了一个NetCore的Web项目.打算在Models文件夹下生成数据库表的实体类. 二.在程序包管理控制台,输入“Scaffold-DbContext "Serve ...

  5. EntityFramework Core 2.x (ef core) 在迁移中自动生成数据库表和列说明

    在项目开发中有没有用过拼音首字母做列名或者接手这样的项目? 看见xmspsqb(项目审批申请表)这种表名时是否有一种无法抑制的想肛了取名的老兄的冲动? 更坑爹的是这种数据库没有文档(或者文档老旧不堪早 ...

  6. 利用DBExportDoc V1.0 For MySQL自动生成数据库表结构文档

    对于DBA或开发来说,如何规范化你的数据库表结构文档是灰常之重要的一件事情.但是当你的库,你的表排山倒海滴多的时候,你就会很头疼了. 推荐一款工具DBExportDoc V1.0 For MySQL( ...

  7. EF CodeFirst关于Mysql如何自动生成数据库表

    相对于sqlserver数据库,mysql的配置过程相对麻烦一些,我们从0讲起. 1.新建一个控制台应用程序 右键点击引用--管理NuGet程序包,搜索Mysql.Data.Entity并安装,安装完 ...

  8. oracle数据库自动生成数据库表结构文档(亲测有效)

    import java.awt.Color; import java.io.FileOutputStream; import java.sql.Connection; import java.sql. ...

  9. T4自动生成数据库C#实体类学习(1)

    第一个测试的Demo <#@ template language="C#" debug="True" hostspecific="True&qu ...

随机推荐

  1. linux下修改tomcat内存大小

    转载自:http://blog.sina.com.cn/s/blog_7fb5109d0101o49a.html 1.  出现此问题的原因:       在tomcat中发布了多个webapp引用,每 ...

  2. NCPC 2015 October 10, 2015 Problem D

    NCPC 2015Problem DDisastrous DowntimeProblem ID: downtimeClaus Rebler, cc-by-saYou’re investigating ...

  3. 60. Permutation Sequence

    题目: The set [1,2,3,…,n] contains a total of n! unique permutations. By listing and labeling all of t ...

  4. Java ANT build.xml

    详情请参考:http://www.cnblogs.com/xionghui/archive/2012/03/13/2393679.html

  5. MongoDB csv文件导入导出

    1.导出到csv文件: 2.从csv导入: 数据经过csv导出导入,有一个非常隐蔽的问题,编写代码时需要注意: 先导入一条数据: 其中Price是double类型: 然后我把该条记录导出到Demo.c ...

  6. cocospod 安装和使用 podfile 问题解决

    Podfile 不识别 usr_framework!,系本地Pods版本太低,要在0.36以上. 以下转自:http://blog.csdn.net/eqera/article/details/393 ...

  7. Xcode常用代码块

    Xcode的代码片段(Code Snippets)创建自定义的代码片段,当你重用这些代码片段时,会给你带来很大的方便. 常用的: 1.strong:@property (nonatomic,stron ...

  8. Cocoapods的安装报错 - Error installing pods:activesupport requires Ruby version >=2.2.2

    1.打开终端 2 移除现有 Ruby 默认源 输入以下指令 $gem sources --remove https://rubygems.org/ 3.使用新的源 输入以下指令 $gem source ...

  9. 数据结构之DFS与BFS实现

    本文主要包括以下内容 邻接矩阵实现无向图的BFS与DFS 邻接表实现无向图的BFS与DFS 理论介绍 深度优先搜索介绍 图的深度优先搜索(Depth First Search),和树的先序遍历比较类似 ...

  10. 数据结构和算法 – 5.模式匹配和文本处理

    了使用正则表达式,需要把 RegEx 类引入程序.大家可以在 System.Text.RegularExpression 名字域中找到这种类.一旦把这种类导入了程序,就需要决定想要用 RegEx 类来 ...