我需要通过API将大量数据上传到数据库中,并且我正在考虑使用EFCore.BulkExtensions。不幸的是,数据将不包括自动生成的主键(Id).
但是,我们有一个独特的复合键,它将包含在数据中。我确实需要将Id保留为模型中的关键属性,因为我需要使用它作为几个子级的外键(我已经能够使用BulkInsert父级和子级使用IncludeGraph,尽管我无法为BulkUpdate或BulkInsertOrUpdate设置它-参见下面)。
当我没有主键时,处理更新的最有效方法是什么?我是否应该使用BulkRead根据唯一的复合键获取Id,选择所有三个字段,然后将其映射到记录列表中?或者有其他方法来处理这个问题(可能类似于实体框架扩展的ColumnPrimaryKeyExpression )。
当父记录是更新时,如果子记录也是Upsert,那么会出现问题吗?这些记录在缺少主键和唯一的复合键时会遇到与父键相同的问题。
提前感谢!
发布于 2022-01-07 14:51:25
我已经决定使用.AsNoTracking()检索基于键的Linq查询所需的数据,然后将Id与要更新的数据匹配。由于其他一些限制,我需要使用ForEach在每个记录上运行一些业务规则,然后再通过BulkUpdate运行,所以希望能够同时完成匹配。
发布于 2021-12-29 15:37:47
我建议研究其他办法。例如,linq2db.EntityFrameworkCore可以处理批量操作的所有内容。请注意,我是其中一个创造者。
如何插入或更新百万行:
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();https://stackoverflow.com/questions/70513615
复制相似问题