Затем добавьте свойство NotMapped, которое будет отображать значение Make экземпляра Car, устранив необходимость в классе CarViewModel из главы 21. Если связанная информация Make была извлечена из базы данных с записью Car, то значение MakeName отображается. Если связанные данные не были извлечены, тогда для свойства отображается строка Unknown (т.е. производитель не известен). Как вы должны помнить, свойства с атрибутом [NotMapped] не относятся к базе данных и существуют только внутри сущности. Добавьте следующий код:

[NotMapped]

public string MakeName => MakeNavigation?.Name ?? "Unknown";

Переопределите ToString для отображения информации о транспортном средстве:

public override string ToString

{

  // Поскольку столбец PetName может быть пустым,.

  // определить стандартное имя **No Name**

  return $"{PetName ?? "**No Name**"} is a {Color} {MakeNavigation?.Name}

    with ID {Id}.";

}

Добавьте к свойству MakeId атрибуты [Required] и [DisplayName]. Несмотря на то что инфраструктура EF Core считает свойство MakeId обязательным, т.к. оно не допускает значение null, механизму проверки достоверности ASP.NET Core нужен атрибут [Required]. Ниже приведен модифицированный код:

[Required]

[DisplayName("Make")]

public int MakeId { get; set; }

Финальное изменение заключается в добавлении свойства IsDrivable типа bool, не допускающего значения null, с поддерживающим полем, допускающим null, и отображаемым именем:

private bool? _isDrivable;

[DisplayName("Is Drivable")]

public bool IsDrivable

{

  get => _isDrivable ?? false;

  set => _isDrivable = value;

}

На этом обновление сущностного класса Car завершено.

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

Для таблицы Customers был создан шаблонный сущностный класс по имени Customer. Приведите операторы using к следующему виду:

using System;

using System.Collections.Generic;

using System.ComponentModel.DataAnnotations.Schema;

using System.Text.Json.Serialization;

using AutoLot.Models.Entities.Base;

using AutoLot.Models.Entities.Owned;

Унаследуйте класс Customer от BaseEntityn удалите свойства Id и TimeStamp. Удалите конструктор и директиву #pragma nullable disable, после чего добавьте атрибут [Table] со схемой. Удалите свойства FirstName и LastName, т.к. они будут заменены принадлежащим сущностным классом Person. Вот как выглядит код в настоящий момент:

namespace AutoLot.Models.Entities

{

  [Table("Customers", Schema = "dbo")]

  public partial class Customer : BaseEntity

  {

    [InverseProperty(nameof(CreditRisk.Customer))]

    public virtual ICollection CreditRisks { get; set; }

    [InverseProperty(nameof(Order.Customer))]

    public virtual ICollection Orders { get; set; }

  }

}

Подобно сущностному классу Car в коде по-прежнему присутствуют проблемы, которые необходимо устранить, к тому же понадобится добавить принадлежащий сущностный класс. К навигационным свойствам нужно добавить атрибут [Jsonlgnore], атрибуты обратных навигационных свойств потребуется обновить с использованием суффикса Navigation, типы необходимо изменить на IEnumerable с инициализацией, а модификатор virtual удалить. Ниже показан модифицированный код:

[JsonIgnore]

[InverseProperty(nameof(CreditRisk.CustomerNavigation))]

public IEnumerable CreditRisks { get; set; } =

  new List;

[JsonIgnore]

[InverseProperty(nameof(Order.CustomerNavigation))]

public IEnumerable Orders { get; set; } = new List;

Осталось лишь добавить свойство с типом принадлежащего сущностного класса. Отношение будет позже сконфигурировано посредством Fluent API.

public Person PersonalInformation { get; set; } = new Person;

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

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