Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
[InlineData(4, "Clunker")][InlineData(5, "Bimmer")][InlineData(6, "Hank")][InlineData(7, "Pinky")][InlineData(8, "Pete")][InlineData(9, "Brownie")]public void ShouldGetValueFromStoredProc(int id, string expectedName){ Assert.Equal(expectedName, new CarRepo(Context).GetPetName(id));}Создание записей
Записи добавляются в базу данных за счет их создания в коде, добавления к
DbSet<T>SaveChanges()/SaveChangesAsync()SaveChanges()ChangeTrackerВспомните, что метод
SaveChanges()Все операторы SQL, показанные далее в разделе, были получены с применением профилировщика SQL Server.
На заметку! Записи можно добавлять также с использованием класса, производного от
DbContextDbSet<T>DbSet<T>DbContextAdd()/AddRange()Состояние сущности
Когда сущность создана с помощью кода, но еще не была добавлена в
DbSet<T>EntityStateDetachedDbSet<T>EntityStateAddedSaveChanges()EntityStateUnchangedДобавление одной записи
В следующем тесте демонстрируется добавление одиночной записи в таблицу
Inventory[Fact]public void ShouldAddACar(){ ExecuteInATransaction(RunTheTest); void RunTheTest() { var car = new Car { Color = "Yellow", MakeId = 1, PetName = "Herbie" }; var carCount = Context.Cars.Count(); Context.Cars.Add(car); Context.SaveChanges(); var newCarCount = Context.Cars.Count(); Assert.Equal(carCount+1,newCarCount); }}Ниже приведен выполняемый оператор SQL. Обратите внимание, что у недавно добавленной сущности запрашиваются свойства, сгенерированные базой данных (
IdTimeStampexec sp_executesql N'SET NOCOUNT ON;INSERT INTO [dbo].[Inventory] ([Color], [MakeId], [PetName])VALUES (@p0, @p1, @p2);SELECT [Id], [IsDrivable], [TimeStamp]FROM [dbo].[Inventory]WHERE @@ROWCOUNT = 1 AND [Id] = scope_identity();',N'@p0 nvarchar(50),@p1 int,@p2 nvarchar(50)',@p0=N'Yellow',@p1=1,@p2=N'Herbie'Добавление одной записи с использованием метода Attach()
Когда первичный ключ сущности сопоставлен со столбцом идентичности в SQL Server, исполняющая среда EF Core будет трактовать экземпляр сущности как добавленный (
AddedCarIdChangeTrackerAddedSaveChanges()[Fact]public void ShouldAddACarWithAttach(){ ExecuteInATransaction(RunTheTest); void RunTheTest() { var car = new Car { Color = "Yellow", MakeId = 1, PetName = "Herbie" }; var carCount = Context.Cars.Count(); Context.Cars.Attach(car); Assert.Equal(EntityState.Added, Context.Entry(car).State);