我想使用 EF 代码优先方法。
我读过这篇文章:
并创建了我的 BL 课程
public class AppData
{
public string Id { get; set; }
public string Url { get; set; }
public AppData_OptionsDialog OptionsDialog { get; set; }
public AppData_Compatibility Compatibility { get; set; }
}
public class AppData_Compatibility
{
public int Id { get; set; }
public string Platform { get; set; }
public string MaxVersion { get; set; }
}
public class AppData_OptionsDialog
{
public int Id { get; set; }
public string DisplayName { get; set; }
public string AppDesc { get; set; }
public string PrivacyPolicyUrl { get; set; }
public string TermsOfUseUrl { get; set; }
}
public class AppsDataContext : System.Data.Entity.DbContext
{
public AppsDataContext() : base("MaMDB") { }
public DbSet<Conduit.Mam.Common.BlData.AppsData.AppData> AppsData { get; set; }
public DbSet<Conduit.Mam.Common.BlData.AppsData.AppData_Compatibility> AppData_Compatibilities { get; set; }
public DbSet<Conduit.Mam.Common.BlData.AppsData.AppData_OptionsDialog> AppData_OptionsDialogs { get; set; }
}
我在数据库中创建了对应的表。
我了解 EF 使用约定优于配置。
那么它是否神奇地将类映射到数据库?无需生成 em
我尝试对这些方法进行测试:
public IList<Conduit.Mam.Common.BlData.AppsData.AppData> GetAll()
{
var apps = from app in AppsDataContext.AppsData
select app;
return apps.ToList();
}
但得到以下错误:
在模型生成期间检测到一个或多个验证错误:
\tSystem.Data.Entity.Edm.EdmEntityType:名称:架构中的每个类型名称都必须是唯一的。类型名称“AppData_OptionsDialog”已定义。\tSystem.Data.Entity.Edm.EdmEntityType:名称:架构中的每个类型名称都必须是唯一的。类型名称“AppData_Compatibility”已定义。
我已经看到了这个答案,但它对我没有帮助