亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

ahjesus使用T4模板自動維護實體

2019-11-17 03:00:26
字體:
來源:轉載
供稿:網友

ahjesus使用T4模板自動維護實體

在entity項目里新建模板DBEntity.tt

<#@ template debug="false" hostspecific="true" language="C#" #><#@ include file="$(SolutionDir)/Packages/T4.TemplateFileManager.2.1.2/tools/ttinc/TemplateFilemanager.CS.ttinclude" #><#@ include file="$(SolutionDir)/Packages/T4.TemplateFileManager.2.1.2/tools/ttinc/DbHelper.CS.ttinclude"  #><#@ output extension=".txt" #><# // Recommended editor: Tangible T4 Editor (http://t4-editor.tangible-engineering.com/Download_T4Editor_Plus_ModelingTools.html)// after save SimpleSample.tt, the output will be generated in the TestFolder of the PRojectvar fileProperties = new FileProperties(){    BuildAction = BuildAction.Compile};var fileManager = TemplateFileManager.Create(this);fileManager.IsAutoIndentEnabled = true;fileManager.CanOverwriteExistingFile = true;fileManager.StartHeader();#>//<summary file="$filename$" company="ldy">//------------------------------------------------------------------------------// <auto-generated>//    此代碼是根據模板生成的。////    手動更改此文件可能會導致應用程序中發生異常行為。//    如果重新生成代碼,則將覆蓋對此文件的手動更改。//出自 http://www.49028c.com/ahjesus 尊重作者辛苦勞動成果,轉載請注明出處,謝謝!// </auto-generated>//------------------------------------------------------------------------------// </summary><# fileManager.EndBlock();var paramTmpl = ParamTextTemplate.Create(this.Host);var session = ParamTextTemplate.GetSessionObject();    var DbTables = DbHelper.GetDbTables(config.ConnectionString, config.DbDatabase);    foreach(var table in DbTables){        fileManager.StartNewFile(table.TableName + ".cs", config.NameSpace,"",fileProperties);        session["ConnectionString"] = config.ConnectionString;        session["DbDatabase"] = config.DbDatabase;        session["NameSpace"] = config.NameSpace;        session["TableName"] = table.TableName;        string output = paramTmpl.TransformText("EntityContent.tt", session);        this.Write(output);    }fileManager.Process();#><#+     public class config{    public static readonly string ConnectionString="Data Source=192.168.1.10;Initial Catalog=TongJi;User ID=sa;PassWord=123456";    public static readonly string DbDatabase="TongJi";    public static readonly string TableName="TAd";    public static readonly string NameSpace="__System.Entity";}#>

再新建EntityContent.tt

<#@ template debug="false" hostspecific="false" language="C#" #><#@ assembly name="System.Core.dll" #><#@ assembly name="System.Data.dll" #><#@ assembly name="System.Data.DataSetExtensions.dll" #><#@ assembly name="System.xml.dll" #><#@ import namespace="System" #><#@ import namespace="System.Xml" #><#@ import namespace="System.Linq" #><#@ import namespace="System.Data" #><#@ import namespace="System.Data.SqlClient" #><#@ import namespace="System.Collections.Generic" #><#@ import namespace="System.IO" #><#@ parameter name="ConnectionString" type="System.String" #><#@ parameter name="DbDatabase" type="System.String" #><#@ parameter name="TableName" type="System.String" #><#@ parameter name="NameSpace" type="System.String" #><#@ include file="$(SolutionDir)/Packages/T4.TemplateFileManager.2.1.2/tools/ttinc/DbHelper.CS.ttinclude"  #><#@ output extension=".txt" #><#if(ConnectionString!=null&&DbDatabase!=null&&TableName!=null&&NameSpace!=null){#>using System;using System.Collections.Generic;namespace <#=NameSpace#>{            public class <#=TableName#> : BaseEntity    {        <#foreach(DbColumn column in DbHelper.GetDbColumns(ConnectionString, DbDatabase, TableName)){#>        /// <summary>        /// <#=GetRemark(column.Remark)#>        /// </summary>                public <#=column.CSharpType#><#if(column.CommonType.IsValueType && column.IsNullable){#>?<#}#> <#=column.ColumnName#> { get; set; }        <#}#>           }}<#}#><#+public string GetRemark(string str){    char[] strArr =str.ToCharArray();    string newStr = "";    foreach (char cr in strArr)    {    if (cr == (char)10)    {    newStr = newStr+cr.ToString()+"http:///";    }    else{    newStr += cr.ToString();    }    }    return newStr;}#>

注意到有一段

<#@ include file="$(SolutionDir)/Packages/T4.TemplateFileManager.2.1.2/tools/ttinc/TemplateFilemanager.CS.ttinclude" #><#@ include file="$(SolutionDir)/Packages/T4.TemplateFileManager.2.1.2/tools/ttinc/DbHelper.CS.ttinclude" #>在解決方案文件夾目錄下的Packages(沒有就新建)里新建T4.TemplateFileManager.2.1.2/tools/ttinc/這個目錄

新建文件TemplateFilemanager.CS.ttinclude

<#@ assembly name="System.Data.DataSetExtensions.dll" #><#@ import namespace="System" #><#@ import namespace="System.Xml" #><#@ import namespace="System.Linq" #><#@ import namespace="System.Data" #><#@ import namespace="System.Data.SqlClient" #><#@ import namespace="System.Collections.Generic" #><#@ import namespace="System.IO" #><#+    public class DbHelper    {        #region GetDbTables                public static List<DbTable> GetDbTables(string connectionString, string database, string tables = null)        {                        if (!string.IsNullOrEmpty(tables))            {                tables = string.Format(" and obj.name in ('{0}')", tables.Replace(",", "','"));            }            #region SQL            string sql = string.Format(@"SELECT                                    obj.name tablename,                                    schem.name schemname,                                    idx.rows,                                    CAST                                    (                                        CASE                                             WHEN (SELECT COUNT(1) FROM sys.indexes WHERE object_id= obj.OBJECT_ID AND is_primary_key=1) >=1 THEN 1                                            ELSE 0                                        END                                     AS BIT) HasprimaryKey                                                                             from {0}.sys.objects obj                                     inner join {0}.dbo.sysindexes idx on obj.object_id=idx.id and idx.indid<=1                                    INNER JOIN {0}.sys.schemas schem ON obj.schema_id=schem.schema_id                                    where type='U' {1}                                    order by obj.name", database, tables);            #endregion            DataTable dt = GetDataTable(connectionString, sql);            return dt.Rows.Cast<DataRow>().Select(row => new DbTable            {                TableName = row.Field<string>("tablename"),                SchemaName = row.Field<string>("schemname"),                Rows = row.Field<int>("rows"),                HasPrimaryKey = row.Field<bool>("HasPrimaryKey")            }).ToList();        }        #endregion        #region GetDbColumns                public static List<DbColumn> GetDbColumns(string connectionString, string database, string tableName, string schema = "dbo")        {            #region SQL            string sql = string.Format(@"                                    WITH indexCTE AS                                    (                                        SELECT                                         ic.column_id,                                        ic.index_column_id,                                        ic.object_id                                            FROM {0}.sys.indexes idx                                        INNER JOIN {0}.sys.index_columns ic ON idx.index_id = ic.index_id AND idx.object_id = ic.object_id                                        WHERE  idx.object_id =OBJECT_ID(@tableName) AND idx.is_primary_key=1                                    )                                    select                                    colm.column_id ColumnID,                                    CAST(CASE WHEN indexCTE.column_id IS NULL THEN 0 ELSE 1 END AS BIT) IsPrimaryKey,                                    co
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久伊人欧美| 国产精品69av| 亚洲欧洲视频在线| 97精品伊人久久久大香线蕉| 最近2019年中文视频免费在线观看| 亚洲第一在线视频| 欧美午夜视频一区二区| 精品久久久久久中文字幕一区奶水| 国产精品精品久久久| 国产综合色香蕉精品| 中文字幕亚洲综合| 亚洲综合日韩中文字幕v在线| 黄色精品在线看| 日韩69视频在线观看| 91精品在线观看视频| 国产精品久久综合av爱欲tv| 欧美老少配视频| 国模吧一区二区三区| 亚洲精品视频免费| 午夜精品久久久久久久久久久久久| 深夜福利亚洲导航| 亚洲欧美国产va在线影院| 欧美性受xxxx黑人猛交| 日韩激情视频在线| 久久久在线免费观看| 亚洲欧美国产精品专区久久| 亚洲欧美中文日韩v在线观看| 欧美电影免费观看| 久久久亚洲国产天美传媒修理工| 日韩电影大片中文字幕| 亚洲精品影视在线观看| 久久亚洲精品中文字幕冲田杏梨| 国产精品亚洲片夜色在线| 国产美女直播视频一区| 欧美视频在线免费看| 亚洲天堂开心观看| 日韩在线播放视频| 欧美性在线视频| 亚洲综合日韩在线| 日韩av在线影院| 国产成人午夜视频网址| 日韩成人在线免费观看| 亚洲精品久久久久久久久| 国产精品久久久久久久久| 欧美性猛交xxxx免费看久久久| 日韩中文第一页| 国产精品美女无圣光视频| 久久久久久久久久久av| 午夜精品一区二区三区在线视频| 18久久久久久| 亚洲xxxx18| 亚洲精品网址在线观看| 91豆花精品一区| 午夜精品久久久久久久99热| 亚洲一区二区在线播放| 亚洲欧美另类国产| 欧美成年人在线观看| 国产精品久久久av| 国产精品777| 日本高清不卡在线| 欧美日韩亚洲精品内裤| 中文字幕精品在线视频| 欧美另类极品videosbest最新版本| 欧美国产精品日韩| 久久综合五月天| 亚洲成人黄色在线| 亚洲美女免费精品视频在线观看| 日韩高清电影免费观看完整| 国产精品av在线播放| 亚洲韩国青草视频| 成人a级免费视频| 日韩在线观看电影| 国产精品白嫩初高中害羞小美女| 久久久国产一区| 欧美日韩在线免费观看| 欧美激情videoshd| 亚洲视频在线观看视频| 亚洲免费av网址| 97色在线观看| 欧美大码xxxx| 免费91麻豆精品国产自产在线观看| 欧美日韩国产一区中文午夜| 国产精品成人aaaaa网站| 国产欧美韩国高清| 亚洲性日韩精品一区二区| 久久亚洲综合国产精品99麻豆精品福利| 欧美亚洲国产日韩2020| 亚洲高清福利视频| 欧美日韩国产色| 国产成人福利网站| 久久久亚洲精选| 国产精品无码专区在线观看| 国产欧美日韩中文| 日韩有码视频在线| 久久在线观看视频| 爽爽爽爽爽爽爽成人免费观看| 98精品国产高清在线xxxx天堂| 97不卡在线视频| 欧美激情在线播放| 成人黄色午夜影院| 热99精品里视频精品| 日韩欧美一区视频| 国产精品自拍偷拍视频| 最好看的2019年中文视频| 国产精品美乳一区二区免费| 国产精品永久在线| 国产97色在线| 精品一区电影国产| 成人a级免费视频| 日韩中文综合网| 久久久久久一区二区三区| 亚洲成人黄色在线观看| 日韩高清人体午夜| 成人免费在线视频网址| 日韩网站免费观看高清| 国产精品一区电影| 欧美激情一区二区三区在线视频观看| 国产精品www色诱视频| 国产欧美在线播放| 久久久亚洲福利精品午夜| 成人亚洲欧美一区二区三区| 欧美一级视频一区二区| 亚洲欧美日韩国产精品| 国产精品情侣自拍| 成人免费淫片视频软件| 欧美一级视频免费在线观看| 亚洲国产成人在线视频| 8050国产精品久久久久久| 日韩免费观看高清| 97久久精品国产| 日韩av影视综合网| 亚洲夜晚福利在线观看| 91啪国产在线| 国产精品激情自拍| 久久青草精品视频免费观看| 成人av资源在线播放| 久久久久这里只有精品| 国产99久久精品一区二区| 国模极品一区二区三区| 日韩在线精品一区| 中文字幕无线精品亚洲乱码一区| 日本一区二区三区在线播放| 国产一区二区三区日韩欧美| 欧美老肥婆性猛交视频| 性欧美在线看片a免费观看| 中文字幕国产精品久久| 欧美中文在线免费| 国产精品高清免费在线观看| 国产精品免费久久久久影院| 国产成人精品综合| 色综合视频一区中文字幕| 午夜精品在线视频| 亚洲美女动态图120秒| 2019中文字幕全在线观看| 久久福利视频网| 亚洲国产日韩欧美在线图片| 日韩av成人在线观看| 92版电视剧仙鹤神针在线观看| 亚洲精品xxx| 欧美人在线观看| 国产精品网站大全| 精品一区二区三区四区| 亚洲精品成人久久久| 久久噜噜噜精品国产亚洲综合|