首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用pimarykey的EFCore.BulkExtensions - BulkUpdate

使用pimarykey的EFCore.BulkExtensions - BulkUpdate
EN

Stack Overflow用户
提问于 2020-05-07 01:49:27
回答 1查看 586关注 0票数 2

我们正在尝试根据主键BulkUpdate(EFCore.BulkExtensions)一个表。我们只需要更新基于IdName,而不是Age

模型

代码语言:javascript
复制
public class Student 
{
    public int Id { get; set; } // Primary Key
    public string Name { get; set; }
    public int Age { get; set; }
}

下面是我尝试使用主键Id更新学生姓名的代码

代码语言:javascript
复制
List<Student> students = new List<Student>();
students.Add(new Student()
{
    Id = 1,
    Name = "Name 1",
    Age = 25
});

var updateByProperties = new List<string> { nameof(Student.Id) };
var propToExclude = new List<string> { nameof(Student.Id) };
var bulkConfig = new BulkConfig { UpdateByProperties = updateByProperties, PropertiesToExclude = propToExclude };
_dbContext().BulkUpdate(students, bulkConfig);

我在这里的预期是,它将更新Id为1的行的列Name,但我得到以下错误

代码语言:javascript
复制
The given key 'Id' was not present in the dictionary.

那么,如何根据主键对表进行BulkUpdate(EFCore.BulkExtensions)。

EN

回答 1

Stack Overflow用户

发布于 2020-06-11 21:57:27

假设Id是一个主键(PK),您只需要更新基于IdName,而不需要更新Age

需要在BulkConfig中设置PropertiesToInclude属性。注意:您不必同时使用PropertiesToIncludePropertiesToExclude。(如果您想包含超过一半的属性,最好使用PropertiesToExclude,但在本例中,您只想更改名称,所以我们将使用属性Include)。

也不需要定义UpdateByProperties,因为您希望通过Id (即主键)来更新数据。UpdateByProperties定义了用于查找以进行更新的属性。

所以代码应该是这样的:

代码语言:javascript
复制
List<Student> students = new List<Student>();
students.Add(new Student()
{
    Id = 1,
    Name = "Name 1",
    Age = 25
});

var propToInclude = new List<string> { nameof(Student.Name) };
var bulkConfig = new BulkConfig { PropertiesToInclude = propToInclude };
_dbContext().BulkUpdate(students, bulkConfig);
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61641818

复制
相关文章

相似问题

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