public int? LineNumber { get; set; }

    [NotMapped]

    public XElement? PropertiesXml

      => (Properties != null)? XElement.Parse(Properties):null;

  }

}

Итак, сущностный класс SeriLogEntry закончен.

На заметку! Свойство TimeStamp в сущностном классе SeriLogEntry отличается от свойства TimeStamp в классе BaseEntity. Имена совпадают, но в этой таблице оно хранит дату и время регистрации записи в журнале (что будет конфигурироваться как стандартная настройка SQL Server), а не rowversion в других сущностях.

<p id="AutBody_Root971"><strong>Класс ApplicationDbContext</strong></p>

Пришло время обновить файл ApplicationDbContext.cs. Начните с приведения операторов using к такому виду:

using System;

using System.Collections;

using System.Collections.Generic;

using AutoLot.Models.Entities;

using AutoLot.Models.Entities.Owned;

using Microsoft.EntityFrameworkCore;

using Microsoft.EntityFrameworkCore.Storage;

using Microsoft.EntityFrameworkCore.ChangeTracking;

using AutoLot.Dal.Exceptions;

Файл начинается с конструктора без параметров. Удалите его, т.к. он не нужен. Следующий конструктор принимает экземпляр DbContextOptions и пока подходит. Перехватчики событий для DbContext и ChangeTracker добавляются позже в главе.

Свойства DbSet необходимо сделать допускающими null, имена скорректировать, а модификаторы virtual удалить. Теперь новую сущность для ведения журнала необходимо добавить. Перейдите к свойствам DbSet и модифицируйте их следующим образом:

public DbSet? LogEntries { get; set; }

public DbSet? CreditRisks { get; set; }

public DbSet? Customers { get; set; }

public DbSet? Makes { get; set; }

public DbSet? Cars { get; set; }

public DbSet? Orders { get; set; }

<p id="AutBody_Root972"><strong>Обновление кода Fluent API</strong></p>

Код Fluent API находится в переопределенной версии метода OnModelCreating и использует экземпляр класса ModelBuilder для обновления модели.

<p id="AutBody_Root973"><strong>Сущность SeriLogEntry</strong></p>

Первое изменение, вносимое в метод OnModelCreating, касается добавления кода Fluent API для конфигурирования сущности SeriLogEntry. Свойство Properties является XML-столбцом SQL Server, а свойство TimeStamp отображается в SQL Server на столбец datetime2 со стандартным значением, установленным в результат функции getdate из SQL Server. Добавьте в метод OnModelCreating следующий код:

modelBuilder.Entity(entity =>

{

  entity.Property(e => e.Properties).HasColumnType("Xml");

  entity.Property(e => e.TimeStamp).HasDefaultValueSql("GetDate");

});

<p id="AutBody_Root974"><strong>Сущность CreditRisk</strong></p>

Далее понадобится модифицировать код сущности CreditRisk. Блок конфигурирования для столбца TimeStamp удаляется, т.к. столбец конфигурируется в BaseEntity. Код конфигурирования навигации должен быть скорректирован с учетом новых имен. Кроме того, выполняется утверждение о том, что навигационное свойство не равно null. Другое изменение связано с конфигурированием свойства типа принадлежащей сущности, чтобы сопоставить с именами столбцов для FirstName и LastName, и добавлением вычисляемого значения для свойства FullName. Ниже показан обновленный блок для сущности CreditRisk с изменениями, выделенными полужирным:

modelBuilder.Entity(entity =>

{

  entity.HasOne(d => d.CustomerNavigation)

      .WithMany(p => p!.CreditRisks)

      .HasForeignKey(d => d.CustomerId)

      .HasConstraintName("FK_CreditRisks_Customers");

  entity.OwnsOne(o => o.PersonalInformation,

    pd =>

    {

      pd.Property(nameof(Person.FirstName))

           .HasColumnName(nameof(Person.FirstName))

           .HasColumnType("nvarchar(50)");

      pd.Property(nameof(Person.LastName))

           .HasColumnName(nameof(Person.LastName))

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

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