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

Entity framework core lazy loading not performed when inserting new instances(插入新实例时未执行实体框架核心延迟加载)
本文介绍了插入新实例时未执行实体框架核心延迟加载的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有两个类:

  • Campaign引用类Customer:

    public class Campaign
    {
        [Key]
        [Required]
        public int id { get; set; }
        public int? CustomerId { get; set; }
        [ForeignKey("CustomerId")]
        public virtual Customer customer { get; set; }
    }
    
  • 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; }
    }
    

下面是一个Insert方法:

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

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

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

在对现有记录执行提取操作时,惰性加载工作正常。

推荐答案

感谢poke

解决方案是:

  1. 使用CreateProxy为您的实体创建代理:

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

    _context.Entry(toCreate).CurrentValues.SetValues(Campaign);
    
  3. 最后,将代理对象保存到上下文:

    _context.Add(toCreate);
    await _context.SaveChangesAsync();`
    

完整方法如下:

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;
}

这篇关于插入新实例时未执行实体框架核心延迟加载的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)