.net自动生成数据库表的类
// 获取到所有的用户表.
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自动生成数据库表的类的更多相关文章
- Mybatis总结之如何自动生成数据库表结构
一般情况下,用Mybatis的时候是先设计表结构再进行实体类以及映射文件编写的,特别是用代码生成器的时候. 但有时候不想用代码生成器,也不想定义表结构,那怎么办? 这个时候就会想到Hibernate, ...
- 【工具篇】利用DBExportDoc V1.0 For MySQL自动生成数据库表结构文档
对于DBA或开发来说,如何规范化你的数据库表结构文档是灰常之重要的一件事情.但是当你的库,你的表排山倒海滴多的时候,你就会很头疼了. 推荐一款工具DBExportDoc V1.0 For MySQL( ...
- Intellij IDEA集成mybatis-generator插件自动生成数据库实体操作类
Intellij IDEA集成mybatis-generator插件自动生成数据库实体操作类 转载至:https://blog.csdn.net/fishinhouse/article/details ...
- NetCore使用使用Scaffold-DbContext命令生成数据库表实体类
一.为了模拟项目,本处创建了一个NetCore的Web项目.打算在Models文件夹下生成数据库表的实体类. 二.在程序包管理控制台,输入“Scaffold-DbContext "Serve ...
- EntityFramework Core 2.x (ef core) 在迁移中自动生成数据库表和列说明
在项目开发中有没有用过拼音首字母做列名或者接手这样的项目? 看见xmspsqb(项目审批申请表)这种表名时是否有一种无法抑制的想肛了取名的老兄的冲动? 更坑爹的是这种数据库没有文档(或者文档老旧不堪早 ...
- 利用DBExportDoc V1.0 For MySQL自动生成数据库表结构文档
对于DBA或开发来说,如何规范化你的数据库表结构文档是灰常之重要的一件事情.但是当你的库,你的表排山倒海滴多的时候,你就会很头疼了. 推荐一款工具DBExportDoc V1.0 For MySQL( ...
- EF CodeFirst关于Mysql如何自动生成数据库表
相对于sqlserver数据库,mysql的配置过程相对麻烦一些,我们从0讲起. 1.新建一个控制台应用程序 右键点击引用--管理NuGet程序包,搜索Mysql.Data.Entity并安装,安装完 ...
- oracle数据库自动生成数据库表结构文档(亲测有效)
import java.awt.Color; import java.io.FileOutputStream; import java.sql.Connection; import java.sql. ...
- T4自动生成数据库C#实体类学习(1)
第一个测试的Demo <#@ template language="C#" debug="True" hostspecific="True&qu ...
随机推荐
- Python初识
Python第一天 一.为什么学Python 作为一名linux运维工程师现在越来越感觉不好干了.没有地位,还待背黑锅,并且运维自动化发展的这么快,普通运维岗位的路也越来越窄(因为我 ...
- Match:Cyclic Nacklace(KMP的next数组的高级应用)(HDU 3746)
串珠子 题目大意:给定一个字串,要你找到如果要使之成为循环串,在末尾需要的最小的字数(只能添加字符,不能删减字符) 首先联动一下之前做过的动态规划问题POJ 3280,当然了3280这一题是用的LD, ...
- Divide and Conquer:Monthly Expense(POJ 3273)
Monthly Expense 题目大意:不废话,最小化最大值 还是直接套模板,不过这次要注意,是最小化最大值,而不是最大化最小值,判断的时候要注意 联动3258 #include <iostr ...
- 关于定时器 setTimeout
1.这里不考虑线程问题.把javascript想象成在时间线上运行,页面载入时,首先执行的是<script>标签中的代码,之后,将执行更多代码,当进程空闲时,下个代码就被触发并执行 如图: ...
- 建立controller
复制controller,重建controller 改: @Controller("[productController]") @RequestMapping("/[pr ...
- java的system.arraycopy()方法
java.lang.System的静态方法arraycopy()可以实现数组的复制,讲课的老师说这个方法效率比较高,如果数组有成千上万个元素,那么用这个方法,比用for语句循环快不少.于是我试了试,发 ...
- 谈谈我的编程之路---WAMP(三)
WAMP的一些配置与使用心得(APACHE)说实话,我感觉apache的配置真的还是蛮复杂的,感觉好像又在学一种语言,让我用比较庞大的概念来讲述这些东西,我也没办法做到就以实际应用出发出发,简单的说一 ...
- 《Linux私房菜》笔记和问题记录
鸟哥的Linux私房菜简体首页 对Linux的学习侧重于基本命令和运维相关的部分,最后章节的测试问题不错. 1.VIM程序编辑器 1.所有的Linux都会内建VI:很多软件的编辑接口都会主动呼叫VI: ...
- C# 中的Singleton模式
一般写Singleton基本都是一下这个套路 class Singleton { public static Singleton instance; private Singleton() { } p ...
- OCJP(1Z0-851) 模拟题分析(一)11
Exam : 1Z0-851 Java Standard Edition 6 Programmer Certified Professional Exam 以下分析全都是我自己分析或者参考网上的,定有 ...