插入新实例时未执行实体框架核心延迟加载

kha*_*lil 5 c# lazy-loading entity-framework-core .net-core

我有两个班级:

  • Campaign 其中引用了一个类客户:

    public class Campaign
    {
        [Key]
        [Required]
        public int id { get; set; }
        public int? CustomerId { get; set; }
        [ForeignKey("CustomerId")]
        public virtual Customer customer { get; set; }
    }
    
    Run Code Online (Sandbox Code Playgroud)
  • 并且Customer

    public class Customer
    {
        [Key]
        [Required]
        public int id { get; set; }
        [Required]
        public string name { get; set; }
        [Required]
        public double turnover { get; set; }
        public virtual ICollection<Campaign> campaigns { get; set; }
    }
    
    Run Code Online (Sandbox Code Playgroud)

这是一个插入方法:

async Task<Campaign> ICampaignRepository.InsertCampaign(Campaign campaign)
{
    try
    {
        _context.Campaigns.Add(campaign);
        await _context.SaveChangesAsync();
        return campaign;
    }
    catch (Exception)
    {
        throw;
    }
}
Run Code Online (Sandbox Code Playgroud)

我正在使用Microsoft.EntityFrameworkCore.Proxies包进行延迟加载

添加具有 的活动实例后customerIdcustomer不会在插入的对象中延迟加载。请注意,我尝试id在返回之前获取活动,但问题仍然存在,我想避免customer显式加载。

在对现有记录执行提取操作时,延迟加载非常有效。

kha*_*lil 7

感谢

解决办法是:

  1. 使用CreateProxy以下方法为您的实体创建代理:

    Campaign toCreate = _context.Campaigns.CreateProxy();
    
    Run Code Online (Sandbox Code Playgroud)
  2. 将新值传输到您的代理对象:

    _context.Entry(toCreate).CurrentValues.SetValues(Campaign);
    
    Run Code Online (Sandbox Code Playgroud)
  3. 最后,将您的代理对象保存到上下文中:

    _context.Add(toCreate);
    await _context.SaveChangesAsync();`
    
    Run Code Online (Sandbox Code Playgroud)

这是完整的方法:

async Task<Campaign> ICampaignRepository.InsertCampaign(Campaign campaign)
{
    Campaign toCreate = _context.Campaigns.CreateProxy();
    _context.Entry(toCreate).CurrentValues.SetValues(campaign);
    _context.Add(toCreate);
    await _context.SaveChangesAsync();
    return toCreate;
}
Run Code Online (Sandbox Code Playgroud)


归档时间:

查看次数:

1058 次

最近记录:

6 年,10 月 前