首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >当数据不包括主键时使用EFCore.BulkExtensions执行UPSERT的有效方法

当数据不包括主键时使用EFCore.BulkExtensions执行UPSERT的有效方法
EN

Stack Overflow用户
提问于 2021-12-28 23:26:24
回答 2查看 1K关注 0票数 0

我需要通过API将大量数据上传到数据库中,并且我正在考虑使用EFCore.BulkExtensions。不幸的是,数据将不包括自动生成的主键(Id).

但是,我们有一个独特的复合键,它将包含在数据中。我确实需要将Id保留为模型中的关键属性,因为我需要使用它作为几个子级的外键(我已经能够使用BulkInsert父级和子级使用IncludeGraph,尽管我无法为BulkUpdate或BulkInsertOrUpdate设置它-参见下面)。

当我没有主键时,处理更新的最有效方法是什么?我是否应该使用BulkRead根据唯一的复合键获取Id,选择所有三个字段,然后将其映射到记录列表中?或者有其他方法来处理这个问题(可能类似于实体框架扩展的ColumnPrimaryKeyExpression )。

当父记录是更新时,如果子记录也是Upsert,那么会出现问题吗?这些记录在缺少主键和唯一的复合键时会遇到与父键相同的问题。

提前感谢!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2022-01-07 14:51:25

我已经决定使用.AsNoTracking()检索基于键的Linq查询所需的数据,然后将Id与要更新的数据匹配。由于其他一些限制,我需要使用ForEach在每个记录上运行一些业务规则,然后再通过BulkUpdate运行,所以希望能够同时完成匹配。

票数 0
EN

Stack Overflow用户

发布于 2021-12-29 15:37:47

我建议研究其他办法。例如,linq2db.EntityFrameworkCore可以处理批量操作的所有内容。请注意,我是其中一个创造者。

如何插入或更新百万行:

代码语言:javascript
复制
var items = ...

using var db = context.CreateLinqToDBConnection();

// temporary table will be crated and items will be inserted as fast as possible
using var temp = db.CreateTempTable(items);

var destinationTable = context.SomeTable.ToLinqToDBTable();
// or
var destinationTable = db.GetTable<SomeTable>();

destinationTable
    .Merge()
    .Using(temp)
    .On((target, source) => target.SomeValue == source.SomeValue)
    .InsertWhenNotMatched(source => new SomeTable
    {
        SomeValue = source.SomeValue
        ... // other fields
    })
    .UpdateWhenMatched((target, source) => new SomeTable
    {
        OtherValue = source.OtherValue 
        ... // other fields
    })
    .Merge();
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/70513615

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档