- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
尝试创建一个相当简单的 T4,我正在尝试加载一些我以后可以使用的值:
<#@ template debug="false" hostspecific="false" language="C#" #>
<#@ assembly name="System.Core" #>
<#@ assembly name="c:\users\<username>\documents\visual studio 2015\Projects\2_DataModelGenerator\packages\EntityFramework.6.1.3\lib\net45\EntityFramework.dll" #>
<#@ assembly name="c:\users\<username>\documents\visual studio 2015\Projects\2_DataModelGenerator\packages\EntityFramework.6.1.3\lib\net45\EntityFramework.SqlServer.dll" #>
<#@ assembly name="c:\users\<username>\documents\visual studio 2015\Projects\2_DataModelGenerator\2_Data\bin\Debug\2_Data.dll" #>
<#@ import namespace="System.Linq" #>
<#@ import namespace="System.Text" #>
<#@ import namespace="System.Data" #>
<#@ import namespace="System.Collections.Generic" #>
<#@ import namespace="2_Data" #>
<#@ output extension=".cs" #>
<#
DevEntities dbContext = new DevEntities();
var labelClassNames = (from sd in dbContext.tblDatas
where sd.SID == 155
select new
{
SID = sd.SID.ToString(),
SValue = sd.SValue.ToString()
}).ToList();
#>
当我保存 T4 时出现此错误:
Error Running transformation: System.MissingMethodException: Method not found: 'System.Data.Entity.DbSet`1<2_Data.tblData> 2_Data.DevEntities.get_tblDatas()'
我已经在另一个解决方案(使用 EF 6.1.3)中测试了这段代码,它可以正常工作(将数据加载到 var labelClassNames
)。似乎只存在于 T4 模板中。
我需要导入另一个命名空间吗?我不确定我错过了什么!
更新:
在我的 TT 代码中:
dbc context = new dbc();
DevEntities mdc = new DevEntities();
mdc = context.returnContext();
在我的类库中添加了一个类:
public class dbc
{
private DevEntities dbContext;
public dbc()
{
dbContext = new DevEntities();
}
public DevEntities returnContext()
{
return dbContext;
}
}
和之前一样的错误:
Running transformation: System.MissingMethodException: Method not found: 'System.Data.Entity.DbSet
但是,当我调试 t4 模板时,我收到一条不同的消息:
No connection string named 'DevEntities' could be found in the application config file.
但是,我已经将包含 .edmx 文件的类库中的 App.config 文件复制到包含 .tt 文件的项目中
有什么想法吗?
最佳答案
T4模板在同一个项目中的类是不可见的,为了简化它的调试,下面一步一步地在EntityFramework中成功运行T4,没有问题并且易于调试:
第 1 步:为模型创建一个单独的类库项目
为模型创建一个单独的类库项目,以供您的应用程序和 T4 模板引用。
这也简化了单元测试并解决了 T4 的许多问题。
第二步:解析连接字符串
为了避免配置文件的问题并正确配置connectionString,创建一个扩展Context类的分部类以避免在重新生成上下文时覆盖。定义新的重载构造函数。
例如,NorthwindEntities
using System.Data.Entity;
namespace NorthWin
{
public partial class NorthwindEntities : DbContext
{
public NorthwindEntities(string connString)
: base(connString)
{
}
}
}
第 3 步:在单独的类中创建所有 DAL 方法
在 T4 模板中需要的所有方法,在同一个类库项目中的单独类中创建它,并从 T4 模板中调用它们。
在您的类中显式定义 connectionString(注意连接字符串中的单引号)。编辑:或者您可以使用包含模板。示例:
using System.Linq;
namespace NorthWin
{
public class DAL
{
string ConnectionString = @"metadata=res://*/NorthWind.csdl|res://*/NorthWind.ssdl|res://*/NorthWind.msl;provider=System.Data.SqlClient;provider connection string='data source=myserver;initial catalog=Northwind;persist security info=True;user id=xxx;password=yyy;MultipleActiveResultSets=True;App=EntityFramework';";
public DAL (string connString)
{
ConnectionString =connString;
}
public int GetCustomerCount()
{
var n = 0;
// call ye new overload constructor
using (var ctx = new NorthwindEntities(ConnectionString))
{
n = ctx.Customers.Count();
}
return n;
}
}
}
第 4 步:构建您的 T4定义 EntityFramework 的最小程序集并调用 DAL 方法
例子
<#@ template debug="false" hostspecific="true" language="C#" #>
<#@ output extension=".txt" #>
<#@ assembly name="System.Xml"#>
<#@ assembly name="$(TargetDir)NorthWin.dll" #>
<#@ assembly name="$(TargetDir)EntityFramework.dll" #>
<#@ assembly name="$(TargetDir)EntityFramework.SqlServer.dll" #>
<#@ assembly name="EnvDTE" #>
<#@ assembly name="System.Configuration" #>
<#@ import namespace="System.Configuration" #>
<#@ import namespace="System" #>
<#@ import namespace="System.Linq" #>
<#@ import namespace="System.Collections.Generic" #>
<#@ import namespace="NorthWin" #>
<#
int n=0;
var dal = new DAL();
/ /call DAL methods
n= dal.GetCustomerCount();
#>
<#= n #>
{
... // More code here.
}
T4 模板的输出:
114
{
... // More code here.
}
编辑:
您可以使用包含文件从配置文件中获取连接字符串,如下所述:
Injecting Your Web.Config Connection String Into Your T4 Template
然后您将连接字符串传递给具有接受连接字符串的构造函数的 DAL 类。
在你的模板中添加这段代码
<#@ include file="ConfigurationAccessor.ttinclude" #>
<#
var config = new ConfigurationAccessor((IServiceProvider)this.Host, @"path\to\ProjectWithConfig.csproj");
string connectionString = config.ConnectionStrings["MainConnectionString"].ConnectionString;
#>
关于c# - T4 - Entity Framework 错误 : Method not found: 'System.Data.Entity.DbSet` 1,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38879731/
我有一个带有帮助页面的 Web API 2 项目,该项目在本地运行良好,但当我将其推送到 Azure 时抛出此错误: Method not found: 'System.String System.S
我有两台服务器,但通常运行相同的设置 - IIS、SQL Server 等。一台给我这个错误,另一台没有。我从 Visual Studio 向两者发布相同的代码。 它们都在运行 .NET CLR Ve
System.out声明为 public static final PrintStream out。 但是你可以调用System.setOut()重新分配它。 嗯?如果它是 final,这怎么可能?
System.out被声明为 public static final PrintStream out。 但是您可以调用System.setOut()重新分配它。 嗯?如果是 final,这怎么可能?
我有这个 linq 查询: private void GetReceivedInvoiceTasks(User user, List tasks) { var areaIds = user.A
我有一个 MonoTouch 应用程序,当我为设备编译它时,出现以下错误: Error MT2002: Can not resolve reference: System.Boolean System
您好,我有一个名为 DailyVisitReport 的 View 。在该 View 中,我有两个名为 FromDate 和 toDate 的字段。如果我选择 FromDate 和 ToDate 取决
是否可以从 ObjectContext 对象中读取元组列表? 我在存储过程中有类似这样的数据库查询 SELECT T.Id as Item1, -- this is guid T.Wo
我正在尝试创建 Odata 端点,但每当我尝试执行任何涉及日期的查询时都会收到此错误。 我在下面的非常简单示例中重新创建了它。 数据库表 EDMX(片段)
我正在尝试创建 Odata 端点,但每当我尝试执行任何涉及日期的查询时都会收到此错误。 我在下面的非常简单示例中重新创建了它。 数据库表 EDMX(片段)
我有一个方法可以从数据读取器的数据中生成类类型列表。 if (datareader != null && datareader .HasRows) { Dictionary pDict= GetP
我有一些旧的 C++ 代码,它们使用 stdio 进行输入和输出。该代码还通过 fork 生成新进程。它将 stdio 重新映射到每个新进程,以便每个 session 获取其各自的数据。 我正在考虑使
我的应用程序可以很好地构建/链接/部署到模拟器,但我只是第一次尝试将应用程序构建/部署到真实设备,并且链接器失败。 我不使用 System.Console或 ConsoleColor在我的应用程序的任
主要是我很好奇。 我们有一个名为 Unit 的对象在我们的代码库中 - 代表桥梁或道路的组件。在我们的例子中,看到带有 Unit 的 ReactiveUI 命令可能会模棱两可。作为声明中的泛型之一。
我试图将Object变量转换为StreamWriter。但是,它不起作用。有什么错? StreamWriter file = (StreamWriter) myObject; 最佳答案 myObjec
为什么以下不编译? using System; using System.Linq; using System.Linq.Expressions; public static class Extens
我正在使用 Visual Studio Community 2015 开发面向 .NET 4.5 的 Visual Basic 应用程序.我没有编写应用程序,所以我使用 NuGet 添加了所有缺失的依
我刚刚开始使用 powershell,我正在制作一个非常简单的加密功能。我想获取字符串中的每个字符,将其转换为 int 并添加一个选定的数字,然后将其转换回一个字符。 这工作正常: function
一些使用我的应用程序的人似乎变得越来越 System.MissingMethodException: Method not found: 'System.Object System.Windows.T
我是 C# 和实体的新手 我想知道是否有人在这里帮助我。我选择了哪个返回我的 customerid,所以我想将它作为参数传递给我的构造函数,我的构造函数参数类型是 guid 但我的选择类型不同,我不知
我是一名优秀的程序员,十分优秀!