在 ASP.NET MVC 应用程序中,通常会存在多个数据上下文。当需要查询或关联不同上下文中的实体时,需要特别处理,以确保应用程序的高效性和正确性。
一种解决方法是使用 LINQ to Objects 和集合,将多个上下文中的数据分别查询出来后再进行关联。例如:
var customerIds = _context1.Customers.Select(c => c.Id).ToList(); var orders = _context2.Orders.Where(o => customerIds.Contains(o.CustomerId)).ToList();
另一种解决方法是使用 Entity Framework Core 中的模型映射实现跨上下文的关联查询。这需要在两个数据上下文中都定义同名的实体,并将它们映射为同一个表。例如:
public class Customer { public int Id { get; set; } public string Name { get; set; } }
public class Order { public int Id { get; set; } public int CustomerId { get; set; } public decimal TotalAmount { get; set; } }
using Microsoft.EntityFrameworkCore;
public class AnotherContext : DbContext
{
public DbSet
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity()
.ToTable("Customers");
modelBuilder.Entity(e =>
{
e.ToView("Customers");
e.Property(c => c.Id).HasColumnName("Id");
e.Property(c => c.Name).HasColumnName("Name");
});
}
}
然后在代码中使用 Include 扩展方法关联查询:
var orders = _context1.Customers .Include(c => c.Orders) .FirstOrDefault(c => c.Id == customerId) ?.Orders.ToList();
上一篇:不同数据路径的区别
下一篇:不同数据文件的直方图计数