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.
Сущность Car(Inventory)
Для таблицы
Inventory
был создан шаблон сущностного класса по имени
Inventory
, но имя
Car
предпочтительнее. Исправить ситуацию легко: измените имя файла на
Car.cs
и имя класса на
Car
. Атрибут
[Table]
применяется корректно, так что нужно просто добавить схему
dbo
. Обратите внимание, что параметр
Schema
необязателен, поскольку по умолчанию для SQL Server принимается
dbo
, но он был включен ради полноты:
<b>[Table("Inventory", Schema = "dbo")]</b>
[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))]
public virtual ICollection<Order> Orders { get; set; }
}
}
В коде все еще присутствуют проблемы, которые необходимо устранить. Свойства
Color
и
PetName
определены как не допускающие
null
, но их значения не устанавливаются в конструкторе или не инициализируются в определении свойств. Проблема решается с помощью инициализаторов свойств. Кроме того, добавьте к свойству
PetName
атрибут
[DisplayName]
, чтобы сделать название свойства более удобным для восприятия человеком. Обновите свойства, как показано ниже (изменения выделены полужирным):
[Required]
[StringLength(50)]
public string Color { get; set; } = <b>"Gold"</b>;
[Required]
[StringLength(50)]
<b>[DisplayName("Pet Name")]</b>
public string PetName { get; set; } = <b>"My Precious"</b>;
На заметку! Атрибут
[DisplayName]
используется инфраструктурой ASP.NET Core и будет описан в части VIII.
Навигационное свойство
Make
потребуется переименовать в
MakeNavigation
и сделать допускающим
null
, а в обратном навигационном свойстве вместо "магической" строки должно применяться выражение
nameof
языка С#. Наконец, нужно удалить модификатор
virtual
. После всех модификаций свойство приобретает следующий вид:
[ForeignKey(nameof(MakeId))]