Читаем Язык программирования C#9 и платформа .NET5 полностью

Когда сущность имеет числовое свойство, которое определено как первичный ключ, то такое свойство (по умолчанию) отображается на столбец идентичности (Identity) в SQL Server. Исполняющая среда EF Core считает сущность со стандартным (нулевым) значением для свойства ключа новой, а сущность с нестандартным значением — уже присутствующей в базе данных. Если вы создаете новую сущность и устанавливаете свойство первичного ключа в ненулевое число, после чего пытаетесь добавить ее в базу данных, то EF Core откажется добавлять запись, поскольку вставка идентичности не разрешена. Включение вставки идентичности демонстрируется в коде инициализации данных.

<p id="AutBody_Root1052"><strong>Добавление объектного графа</strong></p>

При добавлении сущности в базу данных дочерние записи могут быть добавлены в том же самом обращении без их специального добавления в собственный экземпляр DbSet, если они добавлены в свойство типа коллекции для родительской записи. Например, пусть создается новая сущность Make и в ее свойство Cars добавляется дочерняя запись Car. Когда сущность Make добавляется в свойство DbSet, исполняющая среда EF Core автоматически начинает отслеживание также и дочерней записи Car без необходимости в ее явном добавлении в свойство DbSet. Выполнение метода 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 из IEnumerable.

    ((List)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])

VALUES (@p1, @p2, @p3);

SELECT [Id], [IsDrivable], [TimeStamp]

FROM [dbo].[Inventory]

WHERE @@ROWCOUNT = 1 AND [Id] = scope_identity();

',N'@p1 nvarchar(50),@p2 int,@p3 nvarchar(50)',@p1=N'Yellow',@p2=7,@p3=N'Herbie'

<p id="AutBody_Root1053"><strong>Обновление записей</strong></p>

Записи обновляются за счет их загрузки в DbSet как отслеживаемой сущности, их изменения посредством кода и вызова метода SaveChanges() контекста. При выполнении SaveChanges() объект ChangeTracker сообщает обо всех модифицированных сущностях и исполняющая среда EF Core (наряду с поставщиком баз данных) создает надлежащий оператор SQL для обновления записи (или операторы SQL, если записей несколько).

<p id="AutBody_Root1054"><strong>Состояние сущности</strong></p>

Когда сущность редактируется, EntityState устанавливается в Modified. После успешного сохранения изменений состояние возвращается к Unchanged.

<p id="AutBody_Root1055"><strong>Обновление отслеживаемых сущностей</strong></p>

Обновление одиночной записи очень похоже на добавление одной записи. Вам понадобится загрузить запись из базы данных, внести в нее какие-то изменения и вызвать метод SaveChanges(). Обратите внимание, что вам не нужно вызывать Update()/UpdateRange() на экземпляре DbSet, поскольку сущности отслеживаются. Представленный ниже тест обновляет только одну запись, но при обновлении и сохранении множества отслеживаемых сущностей процесс будет таким же:

[Fact]

Перейти на страницу:

Похожие книги

1С: Бухгалтерия 8 с нуля
1С: Бухгалтерия 8 с нуля

Книга содержит полное описание приемов и методов работы с программой 1С:Бухгалтерия 8. Рассматривается автоматизация всех основных участков бухгалтерии: учет наличных и безналичных денежных средств, основных средств и НМА, прихода и расхода товарно-материальных ценностей, зарплаты, производства. Описано, как вводить исходные данные, заполнять справочники и каталоги, работать с первичными документами, проводить их по учету, формировать разнообразные отчеты, выводить данные на печать, настраивать программу и использовать ее сервисные функции. Каждый урок содержит подробное описание рассматриваемой темы с детальным разбором и иллюстрированием всех этапов.Для широкого круга пользователей.

Алексей Анатольевич Гладкий

Программирование, программы, базы данных / Программное обеспечение / Бухучет и аудит / Финансы и бизнес / Книги по IT / Словари и Энциклопедии
1С: Управление торговлей 8.2
1С: Управление торговлей 8.2

Современные торговые предприятия предлагают своим клиентам широчайший ассортимент товаров, который исчисляется тысячами и десятками тысяч наименований. Причем многие позиции могут реализовываться на разных условиях: предоплата, отсрочка платежи, скидка, наценка, объем партии, и т.д. Клиенты зачастую делятся на категории – VIP-клиент, обычный клиент, постоянный клиент, мелкооптовый клиент, и т.д. Товарные позиции могут комплектоваться и разукомплектовываться, многие товары подлежат обязательной сертификации и гигиеническим исследованиям, некондиционные позиции необходимо списывать, на складах периодически должна проводиться инвентаризация, каждая компания должна иметь свою маркетинговую политику и т.д., вообщем – современное торговое предприятие представляет живой организм, находящийся в постоянном движении.Очевидно, что вся эта кипучая деятельность требует автоматизации. Для решения этой задачи существуют специальные программные средства, и в этой книге мы познакомим вам с самым популярным продуктом, предназначенным для автоматизации деятельности торгового предприятия – «1С Управление торговлей», которое реализовано на новейшей технологической платформе версии 1С 8.2.

Алексей Анатольевич Гладкий

Финансы / Программирование, программы, базы данных