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包进行延迟加载。
添加具有 的活动实例后customerId,customer不会在插入的对象中延迟加载。请注意,我尝试id在返回之前获取活动,但问题仍然存在,我想避免customer显式加载。
在对现有记录执行提取操作时,延迟加载非常有效。
感谢戳
解决办法是:
使用CreateProxy以下方法为您的实体创建代理:
Campaign toCreate = _context.Campaigns.CreateProxy();
Run Code Online (Sandbox Code Playgroud)将新值传输到您的代理对象:
_context.Entry(toCreate).CurrentValues.SetValues(Campaign);
Run Code Online (Sandbox Code Playgroud)最后,将您的代理对象保存到上下文中:
_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 次 |
| 最近记录: |