Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
Context.SaveChanges(); var newCarCount = Context.Cars.Count(); Assert.Equal(carCount + 1, newCarCount); }}Добавление нескольких записей одновременно
Чтобы вставить в одной транзакции сразу несколько записей, применяйте метод
AddRange()DbSet<T>[Fact]public void ShouldAddMultipleCars(){ ExecuteInATransaction(RunTheTest); void RunTheTest() { // Для активизации пакетирования должны быть добавлены четыре сущности var cars = new List<Car> { new() { Color = "Yellow", MakeId = 1, PetName = "Herbie" }, new() { Color = "White", MakeId = 2, PetName = "Mach 5" }, 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:
exec sp_executesql N'SET NOCOUNT ON;DECLARE @inserted0 TABLE ([Id] int, [_Position] [int]);MERGE [dbo].[Inventory] USING (VALUES (@p0, @p1, @p2, 0),(@p3, @p4, @p5, 1),(@p6, @p7, @p8, 2),(@p9, @p10, @p11, 3)) AS i ([Color], [MakeId], [PetName], _Position) ON 1=0WHEN NOT MATCHED THENINSERT ([Color], [MakeId], [PetName])VALUES (i.[Color], i.[MakeId], i.[PetName])OUTPUT INSERTED.[Id], i._PositionINTO @inserted0;SELECT [t].[Id], [t].[IsDrivable], [t].[TimeStamp] FROM [dbo].[Inventory] tINNER JOIN @inserted0 i ON ([t].[Id] = [i].[Id])ORDER BY [i].[_Position];',N'@p0 nvarchar(50),@p1 int,@p2 nvarchar(50),@p3 nvarchar(50),@p4 int,@p5 nvarchar(50), @p6 nvarchar(50),@p7 int,@p8 nvarchar(50),@p9 nvarchar(50),@p10 int,@p11 nvarchar(50)', @p0=N'Yellow',@p1=1,@p2=N'Herbie',@p3=N'White',@p4=2,@p5=N'Mach 5',@p6=N'Pink',@p7=3, @p8=N'Avon',@p9=N'Blue',@p10=4,@p11=N'Blueberry'Соображения относительно столбца идентичности при добавлении записей
Когда сущность имеет числовое свойство, которое определено как первичный ключ, то такое свойство (по умолчанию) отображается на столбец идентичности (
IdentityДобавление объектного графа
При добавлении сущности в базу данных дочерние записи могут быть добавлены в том же самом обращении без их специального добавления в собственный экземпляр
DbSet<T>MakeCarsCarMakeDbSet<Make>CarDbSet<Car>SaveChanges()MakeCar[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);