EFCore.BulkExtensions - BulkUpdate с использованием pimarykey - PullRequest
1 голос
/ 06 мая 2020

Мы пытаемся выполнить BulkUpdate ( EFCore.BulkExtensions ) таблицу на основе первичного ключа. Нам нужно обновить ТОЛЬКО Name на основе Id, а не 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);

Я ожидаю, что он обновит столбец Name строки, которая имеет Id как 1, но я получаю следующую ошибку:

The given key 'Id' was not present in the dictionary.

Итак, как сделать I BulkUpdate (EFCore.BulkExtensions) таблицу на основе первичного ключа.

1 Ответ

0 голосов
/ 11 июня 2020

Предположим, что Id - это первичный ключ (PK) , и вам нужно обновить ТОЛЬКО Name на основе Id, а не Age.

Это необходимо установить атрибут PropertiesToInclude внутри BulkConfig. Внимание: не обязательно использовать PropertiesToInclude и PropertiesToExclude одновременно. (Если вы хотите включить более половины атрибутов, лучше использовать PropertiesToExclude, но в вашем случае вы хотите изменить только имя, поэтому мы будем использовать атрибут Include).

Кроме того, это не нужно определять UpdateByProperties, потому что вы хотите обновить данные с помощью Id (что является PK). 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);
...