我正在使用Visual Studio 2010,C#4.0和Entity Framework 5.0。我多年来一直在使用数据库优先开发,但我正在尝试先迁移到代码并遇到问题。阅读和搜索似乎没有解决问题
我将我的问题简化如下 - 我有两个类 - 评估员和文档。
public class Assessor
{
public int AssessorID { get; set; }
public virtual List<Document> Documents { get; set; }
}
public class Document
{
public int DocumentID { get; set; }
public string DocumentLocation { get; set; }
public string DocumentName { get; set; }
public virtual List<Assessor> Assessors { get; set; }
}
带上下文
public class DocumentAssignment : DbContext
{
public DbSet<Assessor> Assessors { get; set; }
public DbSet<Document> Documents { get; set; }
}
评估员可以拥有许多文档,文档可以有许多评估者(经典的多对多关系)。 我使用约定来创建关系,但也使用了流畅的API。我播种了文件表。
我的两个问题: ONE - 我想将文件分配给评估员 - 将此文件保存到数据库的最佳方法是什么?
TWO 我有以下方法来检索分配给评估员的文件:
public static IEnumerable<MaternalDocument> GetAssignedDocumentList(int UserID, string ConnectionString)
{
using (DocumentAssignment dbContext = new DocumentAssignment(ConnectionString))
{
return returnValue = dbContext.MaternalAssessments
.Where(m => m.AssessorID == UserID)
.Include(m => m.MaternalDocuments)
.Select(m => m.MaternalDocuments)
.ToList();
}
}
但由于映射问题,我无法编译。我做错了什么?
答案 0 :(得分:5)
您必须通过覆盖DocumentAssignment中的OnModelCreating来告诉DbContext如何设置多对多关系。将此代码中的AssessorDocuments替换为您的关系表名称。
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
modelBuilder.Entity<Assessor>()
.HasMany(a => a.Documents)
.WithMany(d => d.Assessors)
.Map(m =>
{
m.MapLeftKey("AssessorID");
m.MapRightKey("DocumentID");
m.ToTable("AssessorDocuments");
});
base.OnModelCreating(modelBuilder);
}
将文档分配给评估者(假设文档存在,文档ID为1,评估者存在,评估者ID为1):
using (var context = new DocumentAssignment())
{
var assessor = context.Assessors.Find(1);
var document = context.Documents.Find(1);
assessor.Documents.Add(document);
context.SaveChanges();
}
您的GetAssignedDocumentList方法如下所示:
public static IEnumerable<Document> GetAssignedDocumentList(int UserID)
{
using (var context = new DocumentAssignment())
{
return context.Documents.Where(d => d.Assessors.Any(a => a.AssessorID == UserID));
}
}