实体框架核心中的批量更新

Bulk Update in Entity Framework Core(实体框架核心中的批量更新)

本文介绍了实体框架核心中的批量更新的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我从数据库中取出一堆时间表条目,并使用它们创建发票。一旦我保存了发票并有了ID,我就想用发票ID更新时间表条目。是否有方法可以批量更新实体,而无需一次加载一个实体?

void SaveInvoice(Invoice invoice, int[] timeEntryIds) {
    context.Invoices.Add(invoice);
    context.SaveChanges();

    // Is there anything like?
    context.TimeEntries
        .Where(te => timeEntryIds.Contains(te.Id))
        .Update(te => te.InvoiceId = invoice.Id);
}

推荐答案

如果TimeEntryInvoice关联(检查导航属性),您可能可以执行以下操作:

var timeEntries = context.TimeEntries.Where(t => timeEntryIds.Contains(te.Id)).ToArray();

foreach(var timeEntry in timeEntries)
    invoice.TimeEntries.Add(timeEntry);

context.Invoices.Add(invoice);

//save the entire context and takes care of the ids
context.SaveChanges();

这篇关于实体框架核心中的批量更新的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:实体框架核心中的批量更新

基础教程推荐