new { Color = "Pink", MakeId = 3, PetName = "Avon" },
new { Color = "Blue", MakeId = 4, PetName = "Blueberry" },
};
var carCount = Context.Cars.Count;
Context.Cars.AddRange(cars);
Context.SaveChanges;
var newCarCount = Context.Cars.Count;
Assert.Equal(carCount + 4, newCarCount);
}
}
Операторы добавления пакетируются в единственное обращение к базе данных и запрашиваются все сгенерированные столбцы. Когда результаты запроса поступают в EF Core, сущности обновляются с использованием значений серверной стороны. Вот как выглядит выполняемый оператор SQL:
Соображения относительно столбца идентичности при добавлении записей
Когда сущность имеет числовое свойство, которое определено как первичный ключ, то такое свойство (по умолчанию) отображается на столбец идентичности (
Identity
) в SQL Server. Исполняющая среда EF Core считает сущность со стандартным (нулевым) значением для свойства ключа новой, а сущность с нестандартным значением — уже присутствующей в базе данных. Если вы создаете новую сущность и устанавливаете свойство первичного ключа в ненулевое число, после чего пытаетесь добавить ее в базу данных, то EF Core откажется добавлять запись, поскольку вставка идентичности не разрешена. Включение вставки идентичности демонстрируется в коде инициализации данных.
Добавление объектного графа
При добавлении сущности в базу данных дочерние записи могут быть добавлены в том же самом обращении без их специального добавления в собственный экземпляр
DbSet<T>
, если они добавлены в свойство типа коллекции для родительской записи. Например, пусть создается новая сущность
Make
и в ее свойство
Cars
добавляется дочерняя запись
Car
. Когда сущность
Make
добавляется в свойство
DbSet<Make>
, исполняющая среда EF Core автоматически начинает отслеживание также и дочерней записи
Car
без необходимости в ее явном добавлении в свойство
DbSet<Car>
. Выполнение метода
SaveChanges
приводит к совместному сохранению
Make
и
Car
, что демонстрируется в следующем тесте:
[Fact]
public void ShouldAddAnObjectGraph
{
ExecuteInATransaction(RunTheTest);
void RunTheTest
{
var make = new Make {Name = "Honda"};
var car = new Car { Color = "Yellow", MakeId = 1, PetName = "Herbie" };
// Привести свойство Cars к List<Car> из IEnumerable<Car>.
((List<Car>)make.Cars).Add(car);
Context.Makes.Add(make);
var carCount = Context.Cars.Count;
var makeCount = Context.Makes.Count;
Context.SaveChanges;
var newCarCount = Context.Cars. Count;
var newMakeCount = Context.Makes. Count;
Assert.Equal(carCount+1,newCarCount);
Assert.Equal(makeCount+1,newMakeCount);
}
}
Операторы добавления не пакетируются из-за наличия менее двух операторов, а в SQL Server пакетирование начинается с четырех операторов. Ниже показаны выполняемые операторы SQL:
exec sp_executesql N'SET NOCOUNT ON;
INSERT INTO [dbo].[Makes] ([Name])
VALUES (@p0);
SELECT [Id], [TimeStamp]
FROM [dbo].[Makes]
WHERE @@ROWCOUNT = 1 AND [Id] = scope_identity;
',N'@p0 nvarchar(50)',@p0=N'Honda'
exec sp_executesql N'SET NOCOUNT ON;
INSERT INTO [dbo].[Inventory] ([Color], [MakeId], [PetName])
как отслеживаемой сущности, их изменения посредством кода и вызова метода
SaveChanges
контекста. При выполнении
SaveChanges
объект
ChangeTracker
сообщает обо всех модифицированных сущностях и исполняющая среда EF Core (наряду с поставщиком баз данных) создает надлежащий оператор SQL для обновления записи (или операторы SQL, если записей несколько).