博客
关于我
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 Workbench 使用手册:从入门到精通
查看>>
mysql workbench6.3.5_MySQL Workbench
查看>>
MySQL Workbench安装教程以及菜单汉化
查看>>
MySQL Xtrabackup 安装、备份、恢复
查看>>
mysql [Err] 1436 - Thread stack overrun: 129464 bytes used of a 286720 byte stack, and 160000 bytes
查看>>
MySQL _ MySQL常用操作
查看>>
MySQL – 导出数据成csv
查看>>
MySQL —— 在CentOS9下安装MySQL
查看>>
MySQL —— 视图
查看>>
mysql 不区分大小写
查看>>
mysql 两列互转
查看>>
MySQL 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
mysql 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>
MySQL 中的外键检查设置:SET FOREIGN_KEY_CHECKS = 1
查看>>
Mysql 中的日期时间字符串查询
查看>>
mysql 中索引的问题
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>