说明:。。,有些工具生成实体类没注释,不能和SqlServer的MS_Description属性一起使用,然后照着网上的资源,随便写了个生成模板,自娱自乐向,其实卵用都没有
参考教程
    1、http://www.cnblogs.com/zhongxinWang/p/3540283.html            //批量生成文件
    2、http://www.jb51.net/article/34530.htm                                          //获取表或者字段的扩展属性
1、先把Manager.ttinclude添加到工程里http://www.cnblogs.com/zengxiangzhan/p/3250105.html 
2、添加空白文件  文本模板(.tt)  到工程里,将以下代码添加到工程里,改成你想要的数据库连接语句,然后运行,就会有实体类了,简单暴力的写法,我的主要目的主要是注释。。。,哈,格式不对自己调 ,到时候会多一个文件,就是空白文件的cs文件,删掉就完了。

<#@ template language="C#" debug="True" hostspecific="True" #>
<#@ output extension=".cs" #>
<#@ assembly name="System.Data" #>
<#@ assembly name="System.xml" #>
<#@ assembly name="System.Core"#>
<#@ import namespace="System.Collections.Generic" #>
<#@ import namespace="System.Data.SqlClient" #>
<#@ import namespace="System.Data" #>
<#@ import namespace="System.Linq"#>
<#@include file="$(ProjectDir)\Manager.ttinclude"#>
<# var manager = Manager.Create(Host, GenerationEnvironment); #>
<# manager.StartHeader(); #>
/****************************根据数据库连接生成数据库实体类生成工具,只适合.net 4.0及以上***********************
SELECT value FROM ::fn_listextendedproperty(NULL, 'user', 'dbo', 'table','{0}', {1}, DEFAULT) WHERE name='MS_Description'
{0} : 表名
{1} :
1、DEFAULT作为参数
查询表的扩展属性MS_Description
作为每一个实体类的备注
2、 'column'作为参数
且完整语句如
SELECT value FROM ::fn_listextendedproperty(NULL, 'user', 'dbo', 'table','{0}',DEFAULT, DEFAULT) WHERE name='MS_Description' and objname='{1}'
时,
{0} :表名
{1} :字段名
查询的是某个表的字段名的扩展属性MS_Description
注意:数据库的字段字段名是什么样子,属性名,就是什么样子,所以请一定要有命名规范
*/
using System;
namespace DataComandEntity
{
<# manager.EndBlock(); #>
<#
//数据库连接语句
string ConnectionStr="Data Source=******;Initial Catalog=MeterIndex;Persist Security Info=True;User ID=****;Password=****;pooling=true"; SqlConnection conn = new SqlConnection(ConnectionStr); conn.Open(); System.Data.DataTable schema = conn.GetSchema("TABLES"); //获取数据库架构信息 string selectQuery = "select * from @tableName"; //正确的,后面会用Replace替换 SqlCommand command = new SqlCommand(selectQuery,conn); SqlDataAdapter sda = new SqlDataAdapter(command); System.Data.DataSet ds = new DataSet(); foreach(System.Data.DataRow row in schema.Rows)
{
String strModel="SELECT value FROM ::fn_listextendedproperty(NULL, 'user', 'dbo', 'table','{0}', {1}, DEFAULT) WHERE name='MS_Description'"; //SQL语句模版
String TABLE_NAME=row["TABLE_NAME"].ToString(); //获取表名 manager.StartNewFile(TABLE_NAME+".cs");
//获取表的扩展属性
using(SqlConnection connT1=new SqlConnection(conn.ConnectionString)){
connT1.Open();
using(SqlCommand cmd=new SqlCommand(string.Format(strModel,TABLE_NAME,"DEFAULT"),connT1)){
using(SqlDataReader sdr=cmd.ExecuteReader()){
if(sdr.HasRows){ //如果有结果
sdr.Read();
#>
/// <summary>
/// <#=sdr[0].ToString().Trim()#>
/// </summary>
<#
}
}
}
}
#>
public class <#=TABLE_NAME #>
{
<#
ds.Tables.Clear(); command.CommandText = selectQuery.Replace("@tableName",row["TABLE_NAME"].ToString()); sda.FillSchema(ds, SchemaType.Mapped, row["TABLE_NAME"].ToString()); foreach (DataColumn dc in ds.Tables[].Columns) //遍历列名
{
String COLUMN_NAME=dc.ColumnName.Trim();
using(SqlConnection connT2=new SqlConnection(conn.ConnectionString)){
connT2.Open();
using(SqlCommand cmd2=new SqlCommand()){
//拼接语句
cmd2.CommandText=string.Format(strModel,TABLE_NAME,"'column'")+string.Format(" and objname='{0}'",COLUMN_NAME);
cmd2.Connection=connT2;
using(SqlDataReader sdr2=cmd2.ExecuteReader()){
if(sdr2.HasRows){
sdr2.Read();
#>
/// <summary>
/// <#=sdr2[0].ToString().Trim()#>
/// </summary>
<#
}
}
}
}
#>
public <#= dc.DataType.Name #> <#= COLUMN_NAME #> { get; set; }
<#
}
#>
}
<#
manager.EndBlock();
}
#>
<# manager.StartFooter(); #>
}
<# manager.EndBlock(); #>
<# manager.Process(true); #>

C# T4 模板 数据库实体类生成模板(带注释,娱乐用)的更多相关文章

  1. T4教程2 T4模版引擎之生成数据库实体类

    T4模版引擎之生成数据库实体类   在通过T4模版引擎之基础入门 对T4有了初步印象后,我们开始实战篇.T4模板引擎可以当做一个代码生成器,代码生成器的职责当然是用来生成代码(这不是废话吗).而这其中 ...

  2. [转]T4模版引擎之生成数据库实体类

    本文转自:http://www.cnblogs.com/lzrabbit/archive/2012/07/18/2597953.html 在通过T4模版引擎之基础入门 对T4有了初步印象后,我们开始实 ...

  3. T4模版引擎之生成数据库实体类

    在通过T4模版引擎之基础入门 对T4有了初步印象后,我们开始实战篇.T4模板引擎可以当做一个代码生成器,代码生成器的职责当然是用来生成代码(这不是废话吗).而这其中我们使用的最普遍的是根据数据库生成实 ...

  4. 【EF框架】EF DBFirst 快速生成数据库实体类 Database1.tt

    现有如下需求,数据库表快速映射到数据库实体类 VS给出的两个选择都有问题,并不能实现,都是坑啊 EF .x DbContext 生成器 EF .x DbContext 生成器 测试结果如下 生成文件 ...

  5. [开源] FreeSql.AdminLTE.Tools 根据实体类生成后台管理代码

    前言 FreeSql 发布至今已经有9个月,功能渐渐完善,自身的生态也逐步形成,早在几个月前写过一篇文章<ORM 开发环境之利器:MVC 中间件 FreeSql.AdminLTE>,您可以 ...

  6. linq to sql 项目移植后,数据库实体类需要重新创建?

    项目中,使用LINQ to SQL 访问数据库,代码移植到其他机器上,每次需要重新生成dbml文件,有无方法只要更改app.config呢? 经过试验是可行的: 1.引用system.configur ...

  7. 【干货分享】C# 实体类生成工具

    前言: 项目实战中不论是业务编码还是通用编码,总会归纳出一些通用的工具类.放入项目中一劳永逸,让兄弟姐妹们避免编写重复代码.所以利用了工作之余的时间,将这些散落在多个项目中精致优雅的工具类,归纳起来形 ...

  8. EF:根据实体类生成表结构SQL

    根据实体类生成表结构SQL: PM> Enable-Migrations -ProjectName Domain -StartUpProjectName Handler -Force PM> ...

  9. C#实体类生成XML与XML Schema文档

    一.实体类生成XML private void CreateXML() { Type[] objType = DBEntityRegst(); foreach (var item in objType ...

随机推荐

  1. elasticsearch6.6.2在Centos6.9的安装

    JDK8 做个记录,以防以后忘记能够查看. 1.elastic是java编写的,先搭建运行环境,6.6.2版本必须要jdk8以上版本才可运行,先官网下载jdk,上传服务器 https://www.or ...

  2. 无敌简单快速的文件服务器sgfs

    前言 想要构建一个Linux文件服务器?看看下面几个要求是不是你想要的? 1.只需要单节点部署就够了 2.部署启动简单,下载之后,一键启动,一键关闭 3.不需要任何其他的依赖安装,而且运行时占用内存资 ...

  3. Asp.Net Core 轻松学-使用MariaDB/MySql/PostgreSQL和支持多个上下文对象

    前言 在上一篇文章中(Asp.Net Core 轻松学-10分钟使用EFCore连接MSSQL数据库)[https://www.cnblogs.com/viter/p/10243577.html],介 ...

  4. 《k8s-1.13版本源码分析》- Scheduler启动前逻辑

    本文原始地址(gitbook格式):https://farmer-hutao.github.io/k8s-source-code-analysis/core/scheduler/before-sche ...

  5. C#净化版WebApi框架

    前言 我们都知道WebApi是依赖于Asp.Net MVC的HttpRouteCollection进行路由 . 但WebApi和MVC之间是没有依赖关系的, WebApi的基类ApiControlle ...

  6. C# ASP.NET MVC:使用Cookie记住账号密码

    MVC记住账号密码 使用cookie操作 前端: <div> 用户名:<input type="text" id="UserName" val ...

  7. Spring Boot入门(三):使用Scheduled注解实现定时任务

    在程序开发的过程中,经常会使用定时任务来实现一些功能,比如: 系统依赖于外部系统的非核心数据,可以定时同步 系统内部一些非核心数据的统计计算,可以定时计算 系统内部的一些接口,需要间隔几分钟或者几秒执 ...

  8. PowerDesigner制作UMI图

    首先我们要下载一个PowerDesigner,自己上百度下载哈!嘻嘻!!! 我这个是汉化版的 然后点这个,再到空白的地方点一下就创建好了. 然后单击右边箭头然后双击 不管是制作的图还是代码生成的图都可 ...

  9. gitbook 入门教程之环境要求

    gitbook 是基于 node.js 的命令行工具,首先需要安装并配置好 node.js 环境,然后才能安装gitbook 相关工具. 由于安装工具全部都是国外网站,因此速度可能会很慢,也可能需要F ...

  10. 2018-01-12 Antlr4添加中文变量赋求值,括号,各种问题

    中文编程知乎专栏原文地址 例程(更多测试用例在此): 基数=100 基数×(基数+1)÷2 => 求值为5050 续上文Antlr4实现数学四则运算, 修改的语法规则部分: 程序: 声明+; 声 ...