我试图复制在MSDN上找到的示例。我正在使用ASP.NET和EF 4.1(CTP?)。我已经使用NuGet来安装EntityFramework软件包。EF 4.1异常“提供程序没有返回ProviderManifestToken字符串”
我得到这个错误:The provider did not return a ProviderManifestToken string
... 和数据库永远不会创建。
这里是我的连接字符串:
<add name="HospitalContext"
connectionString=
"data source=.\SQLExpress;initial catalog=NewTestDB;integrated security=True;"
providerName="System.Data.SqlClient"/>
这里是我的代码:
var pat = new Patient { Name = "Shane123132524356436435234" };
db.Patients.Add(pat);
var labResult = new LabResult { Result = "bad", Patient = pat };
int recordAffected = db.SaveChanges();
这里是我的背景:
public class HospitalContext : DbContext
{
static HospitalContext()
{
Database.SetInitializer(new HostpitalContextInitializer());
}
public DbSet<Patient> Patients { get; set; }
public DbSet<LabResult> LabResults { get; set; }
}
public class HostpitalContextInitializer :
DropCreateDatabaseIfModelChanges<HospitalContext>
{
protected override void Seed(HospitalContext context)
{
context.Patients.Add(new Patient { Name = "Fred Peters" });
context.Patients.Add(new Patient { Name = "John Smith" });
context.Patients.Add(new Patient { Name = "Karen Fredricks" });
}
}
这是一个完全使用补丁的SQL 2008系统,与VS 2010 SP1。
在向模型添加[Key]之后,它看起来似乎已经过去了这个问题。我仍然遇到另一个问题,但这可能解决了这个问题。 – bugnuker 2011-03-24 17:53:32
另外,它可能是我的连接字符串中添加了“Intergrated security = true”... – bugnuker 2011-03-24 19:17:20
我在处理'SqlServerCe.Entity.dll'时遇到了同样的异常。 – 2011-07-02 07:37:16