让我澄清一下我的情景。我有一个使用库的WCF服务,在这个库中存在数据库模型(edmx)。
在我的WCF服务中:
[DataContract]
public class QuestionSetInformation
{
[DataMember]
public string Id { get; set; }
[DataMember]
public string SetName { get; set; }
[DataMember]
public string ObjectiveName { get; set; }
}
[ServiceContract]
public interface IService1
{
[OperationContract]
QuestionSetInformation[] GetQuestionSets(string objectiveName);
}
public QuestionSetInformation[] GetQuestionSets(string objectiveName)
{
var query = from r in QuestionRepositoryManager.GetRepositories()
select new QuestionSetInformation()
{
Id = r.Id,
SetName = r.SetName,
ObjectiveName = r.ObjectiveName
};
return query.ToArray();
}
由于我的库使用EDMX,所以我将连接字符串移动到我的WCF,它使用WCF测试客户端完美地工作。它为我提供了我所期待的。
<?xml version="1.0"?>
<configuration>
<configSections>
<section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=5.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
</configSections>
<connectionStrings>
<add name="ContosoDb" connectionString="metadata=res://*/Entities.Model1.csdl|res://*/Entities.Model1.ssdl|res://*/Entities.Model1.msl;provider=System.Data.SqlClient;provider connection string="data source=X;initial catalog=contoso2_db;persist security info=True;user id=X;password=X;multipleactiveresultsets=True;application name=EntityFramework"" providerName="System.Data.EntityClient" />
</connectionStrings>
<entityFramework>
<defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework" />
</entityFramework>
但是在桌面应用程序中一次使用此WCF时,我遇到以下异常:
ServiceReference1.Service1Client service = new ServiceReference1.Service1Client("BasicHttpsBinding_IService1");
ServiceReference1.QuestionSetInformation[] qss = service.GetQuestionSets("something");
FaultException`1未处理使用T4模板生成的代码 对于Database First和Model First开发可能无法正常工作 如果在Code First模式下使用。继续使用Database First或Model 首先确保指定了Entity Framework连接字符串 在执行应用程序的配置文件中。要使用这些类, 使用Code从Database First或Model First生成的 首先使用属性或添加任何其他配置 DbModelBuilder API然后删除抛出此代码的代码 异常。
我在网上调查了这个错误,每个人都讲述了使用连接字符串的问题,但我认为这不是同一个案例。我不知道如何解决它
答案 0 :(得分:0)
这是它使用的连接字符串的问题...它使用某种默认的SqlClient连接字符串(即不是指定三个EF元数据文件的实体框架连接字符串)它认为你在Code First模式下运行。
确保连接字符串的名称相同,或者将要使用的连接字符串名称传递给DbContext构造函数。