Категории
Самые читаемые
ChitatKnigi.com » 🟢Компьютеры и Интернет » Базы данных » Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю

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

Читать онлайн Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
1 ... 431 432 433 434 435 436 437 438 439 ... 642
Перейти на страницу:

Шрифт:

-
+

Интервал:

-
+

Закладка:

Сделать

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(&quot;Inventory&quot;, Schema = &quot;dbo&quot;)]</b>

[Index(nameof(MakeId), Name = &quot;IX_Inventory_MakeId&quot;)]

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. Вот как выглядит код класса после таких изменений:

(window.adrunTag = window.adrunTag || []).push({v: 1, el: 'adrun-4-390', c: 4, b: 390})

namespace AutoLot.Models.Entities

{

  [Table(&quot;Inventory&quot;, Schema = &quot;dbo&quot;)]

  [Index(nameof(MakeId), Name = &quot;IX_Inventory_MakeId&quot;)]

  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(&quot;Inventories&quot;)]

    public virtual Make Make { get; set; }

    [InverseProperty(nameof(Order.Car))]

    public virtual ICollection&lt;Order&gt; Orders { get; set; }

  }

}

В коде все еще присутствуют проблемы, которые необходимо устранить. Свойства Color и PetName определены как не допускающие null, но их значения не устанавливаются в конструкторе или не инициализируются в определении свойств. Проблема решается с помощью инициализаторов свойств. Кроме того, добавьте к свойству PetName атрибут [DisplayName], чтобы сделать название свойства более удобным для восприятия человеком. Обновите свойства, как показано ниже (изменения выделены полужирным):

[Required]

[StringLength(50)]

public string Color { get; set; } = <b>&quot;Gold&quot;</b>;

[Required]

[StringLength(50)]

<b>[DisplayName(&quot;Pet Name&quot;)]</b>

public string PetName { get; set; } = <b>&quot;My Precious&quot;</b>;

На заметку! Атрибут [DisplayName] используется инфраструктурой ASP.NET Core и будет описан в части VIII.

Навигационное свойство Make потребуется переименовать в MakeNavigation и сделать допускающим null, а в обратном навигационном свойстве вместо "магической" строки должно применяться выражение nameof языка С#. Наконец, нужно удалить модификатор virtual. После всех модификаций свойство приобретает следующий вид:

[ForeignKey(nameof(MakeId))]

1 ... 431 432 433 434 435 436 437 438 439 ... 642
Перейти на страницу:
Отывы о книге
Открыть боковую панель
Комментарии
Ксения
Ксения 25.01.2025 - 12:30
Неплохая подборка книг. Прочитаю все однозначно.
Jonna
Jonna 02.01.2025 - 01:03
Страстно🔥 очень страстно
Ксения
Ксения 20.12.2024 - 00:16
Через чур правильный герой. Поэтому и остался один
Настя
Настя 08.12.2024 - 03:18
Прочла с удовольствием. Необычный сюжет с замечательной концовкой
Марина
Марина 08.12.2024 - 02:13
Не могу понять, где продолжение... Очень интересная история, хочется прочесть далее