using System.ComponentModel.DataAnnotations.Schema;

namespace AutoLot.Models.Entities.Base

{

  public abstract class BaseEntity

  {

    [Key, DatabaseGenerated(DatabaseGeneratedOption.Identity)]

    public int Id { get; set; }

    [TimeStamp]

    public byte[]? TimeStamp { get; set; }

  }

}

Все сущности, шаблоны которых созданы из базы данных AutoLot, будут обновлены для применения базового класса BaseEntity.

<p id="AutBody_Root964"><strong>Принадлежащий сущностный класс Person</strong></p>

Сущности Customer и CreditRisk имеют свойства FirstName и LastName. Если в каждой сущности присутствуют одни и те же свойства, тогда можно извлечь выгоду от перемещения этих свойств в принадлежащие классы. Пример с двумя свойствами тривиален, но принадлежащие сущностные классы помогают сократить дублирование кода и повысить согласованность. В дополнение к двум свойствам внутри классов определяется еще одно свойство, отображаемое на вычисляемый столбец SQL Server.

Создайте в каталоге Entities проекта AutoLot.Models новый каталог по имени Owned и добавьте в него новый файл Person.cs, содержимое которого показано ниже:

using System.ComponentModel.DataAnnotations;

using System.ComponentModel.DataAnnotations.Schema;

using Microsoft.EntityFrameworkCore;

namespace AutoLot.Models.Entities.Owned

{

  [Owned]

  public class Person

  {

    [Required, StringLength(50)]

    public string FirstName { get; set; } = "New";

    [Required, StringLength(50)]

    public string LastName { get; set; } = "Customer";

    [DatabaseGenerated(DatabaseGeneratedOption.Computed)]

    public string? FullName { get; set; }

  }

}

Свойство FullName допускает null, т.к. до сохранения в базе данных новые сущности не будут иметь установленных значений. Финальная конфигурация свойства Fullname обеспечивается с использованием Fluent API.

<p id="AutBody_Root965"><strong>Сущность Car(Inventory)</strong></p>

Для таблицы Inventory был создан шаблон сущностного класса по имени Inventory, но имя Car предпочтительнее. Исправить ситуацию легко: измените имя файла на Car.cs и имя класса на Car. Атрибут [Table] применяется корректно, так что нужно просто добавить схему dbo. Обратите внимание, что параметр Schema необязателен, поскольку по умолчанию для SQL Server принимается dbo, но он был включен ради полноты:

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

[Index(nameof(MakeId), Name = "IX_Inventory_MakeId")]

public partial class Car : BaseEntity

{

  ...

}

Обновите операторы using следующим образом:

using System;

using System.Collections.Generic;

using System.ComponentModel;

using System.ComponentModel.DataAnnotations;

using System.ComponentModel.DataAnnotations.Schema;

using System.Text.Json.Serialization;

using AutoLot.Models.Entities.Base;

using Microsoft.EntityFrameworkCore;

Унаследуйте класс Car от BaseEntity, после чего удалите свойства Id и TimeStamp, конструктор и директиву #pragma nullable disable. Вот как выглядит код класса после таких изменений:

namespace AutoLot.Models.Entities

{

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

  [Index(nameof(MakeId), Name = "IX_Inventory_MakeId")]

  public partial class Car : BaseEntity

  {

    public int MakeId { get; set; }

    [Required]

    [StringLength(50)]

    public string Color { get; set; }

    [Required]

    [StringLength(50)]

    public string PetName { get; set; }

    [ForeignKey(nameof(MakeId))]

    [InverseProperty("Inventories")]

    public virtual Make Make { get; set; }

    [InverseProperty(nameof(Order.Car))]

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

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