博客
关于我
Ef+T4模板实现代码快速生成器
阅读量:413 次
发布时间:2019-03-06

本文共 3704 字,大约阅读时间需要 12 分钟。

转载请注明地址: 

效果如图,(点击demo可下载案例)

 

项目结构如图

T4BLL添加BLL.tt文件;

T4Model添加Model文件;

T4DAL添加DAL.tt文件;

T4DAL 添加ADO.NET Entity Data Model选择dababase first 模式;


 

打开Model1.edmx文件下的Model1.tt打开,复制内容替换了T4Model项目下Model.tt文件;

打开Model1.edmx文件下的Model.tt从<#=codeStringGenerator.EntityClassOpening(entity)#>{ 开始选择至 }<# EndNamespace(code); 删除

如下图

复制Model1.tt内容替换BLL.tt、DAL.tt内容,现在Model1.tt已经没有什么意义了,可以删除。


 

打开T4Model的T4模板,修改如下代码,修改完成后保存下就可以生成出Edmx中添加类的Model。

const string inputFile = @"Model1.edmx";//更改为string inputFile = Host.ResolveAssemblyReference("$(ProjectDir)").Replace("T4Model","T4DAL")+"/Model1.edmx";

 

打开T4DAL的T4模板

fileManager.StartNewFile(entity.Name + ".cs");//更改为fileManager.StartNewFile(entity.Name + "_DAL.cs");//---分割线--- public string EntityClassOpening(EntityType entity)    {        return string.Format(            CultureInfo.InvariantCulture,            "{0} {1}partial class {2}{3}",            Accessibility.ForType(entity),            _code.SpaceAfter(_code.AbstractOption(entity)),            _code.Escape(entity),            _code.StringBefore(" : ", _typeMapper.GetTypeName(entity.BaseType)));    }//更改为 public string EntityClassOpening(EntityType entity)    {        return string.Format(            CultureInfo.InvariantCulture,            "{0} {1}partial class {2}_DAL{3}",            Accessibility.ForType(entity),            _code.SpaceAfter(_code.AbstractOption(entity)),            _code.Escape(entity),            _code.StringBefore(" : ", _typeMapper.GetTypeName(entity.BaseType)));    }//---分割线---更改为foreach (var entity in typeMapper.GetItemsToGenerate
(itemCollection)){ fileManager.StartNewFile(entity.Name + "_DAL.cs"); BeginNamespace(code);#>using T4Model;<#=codeStringGenerator.UsingDirectives(inHeader: false)#><#=codeStringGenerator.EntityClassOpening(entity)#>{ ///
/// 新增 /// ///
///
public <#= entity.Name #> Add(<#= entity.Name #> entity){ //内容实现 return null; }}<# EndNamespace(code);}

 


 

打开T4BLL的T4模板

const string inputFile = @"Model1.edmx";//更改为string inputFile = Host.ResolveAssemblyReference("$(ProjectDir)").Replace("T4BLL","T4DAL")+"/Model1.edmx"; //---分割线---fileManager.StartNewFile(entity.Name + ".cs");//更改为fileManager.StartNewFile(entity.Name + "_BLL.cs");//---分割线--- public string EntityClassOpening(EntityType entity)    {        return string.Format(            CultureInfo.InvariantCulture,            "{0} {1}partial class {2}{3}",            Accessibility.ForType(entity),            _code.SpaceAfter(_code.AbstractOption(entity)),            _code.Escape(entity),            _code.StringBefore(" : ", _typeMapper.GetTypeName(entity.BaseType)));    }//更改为 public string EntityClassOpening(EntityType entity)    {        return string.Format(            CultureInfo.InvariantCulture,            "{0} {1}partial class {2}_BLL{3}",            Accessibility.ForType(entity),            _code.SpaceAfter(_code.AbstractOption(entity)),            _code.Escape(entity),            _code.StringBefore(" : ", _typeMapper.GetTypeName(entity.BaseType)));    }//---分割线---更为foreach (var entity in typeMapper.GetItemsToGenerate
(itemCollection)){ fileManager.StartNewFile(entity.Name + "_BLL.cs"); BeginNamespace(code);#>using T4DAL;using T4Model;<#=codeStringGenerator.UsingDirectives(inHeader: false)#><#=codeStringGenerator.EntityClassOpening(entity)#>{ <#= entity.Name #>_DAL dal = new <#= entity.Name #>_DAL(); ///
/// 新增 /// ///
///
public <#= entity.Name #> Add(<#= entity.Name #> entity){ return dal.Add(entity); }}<# EndNamespace(code);}

Host.ResolveAssemblyReference("$(ProjectDir)")是获取项目路径的方法,通过替换项目名称来寻找到edmx文件,从而实现T4模板分离在不同的类库中。

 

 

你可能感兴趣的文章
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>