我们正在尝试根据主键BulkUpdate(EFCore.BulkExtensions)一个表。我们只需要更新基于Id的Name,而不是Age
模型
public class Student
{
public int Id { get; set; } // Primary Key
public string Name { get; set; }
public int Age { get; set; }
}下面是我尝试使用主键Id更新学生姓名的代码
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,但我得到以下错误
The given key 'Id' was not present in the dictionary.那么,如何根据主键对表进行BulkUpdate(EFCore.BulkExtensions)。
发布于 2020-06-11 21:57:27
假设Id是一个主键(PK),您只需要更新基于Id的Name,而不需要更新Age。
需要在BulkConfig中设置PropertiesToInclude属性。注意:您不必同时使用PropertiesToInclude和PropertiesToExclude。(如果您想包含超过一半的属性,最好使用PropertiesToExclude,但在本例中,您只想更改名称,所以我们将使用属性Include)。
也不需要定义UpdateByProperties,因为您希望通过Id (即主键)来更新数据。UpdateByProperties定义了用于查找以进行更新的属性。
所以代码应该是这样的:
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);https://stackoverflow.com/questions/61641818
复制相似问题