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

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

На нашем литературном портале можно бесплатно читать книгу Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю, Троелсен Эндрю . Жанр: Базы данных. Онлайн библиотека дает возможность прочитать весь текст и даже без регистрации и СМС подтверждения на нашем литературном портале litmir.org.
Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
Название: Язык программирования C#9 и платформа .NET5
Дата добавления: 22 август 2024
Количество просмотров: 233
Читать онлайн

Внимание! Книга может содержать контент только для совершеннолетних. Для несовершеннолетних просмотр данного контента СТРОГО ЗАПРЕЩЕН! Если в книге присутствует наличие пропаганды ЛГБТ и другого, запрещенного контента - просьба написать на почту readbookfedya@gmail.com для удаления материала

Язык программирования C#9 и платформа .NET5 читать книгу онлайн

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

В 10-м издании книги описаны новейшие возможности языка C# 9 и .NET 5 вместе с подробным "закулисным" обсуждением, призванным расширить навыки критического мышления разработчиков, когда речь идет об их ремесле.

Книга охватывает ASP.NET Core, Entity Framework Core и многое другое наряду с последними обновлениями унифицированной платформы .NET, начиная с улучшений показателей производительности настольных приложений Windows в .NET 5 и обновления инструментария XAML и заканчивая расширенным рассмотрением файлов данных и способов обработки данных.

Все примеры кода были переписаны с учетом возможностей последнего выпуска C# 9.

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

<b>KEY([CarId])</b>

<b>REFERENCES [dbo].[Cars] ([Id])</b>

<b>ON DELETE CASCADE</b>

GO

<b>ALTER TABLE [dbo].[Radios] CHECK CONSTRAINT [FK_Radios_Cars_CarId]</b>

GO

Обратите внимание на ограничения внешнего ключа и проверки, созданные для зависимой таблицы (Radios).

Отношения "многие ко многим" (нововведение в версии EF Core 5)

В отношении "многие ко многим" каждая сущность содержит навигационное свойство типа коллекции для другой сущности, что в хранилище данных реализуется с использованием таблицы соединения посреди двух сущностных таблиц. Такая таблица соединения именуется в соответствии с двумя таблицами в виде &lt;Сущность1Сущность2&gt;. Имя можно изменить в коде через Fluent API. Таблица соединения имеет отношения "один ко многим" с каждой сущностной таблицей:

namespace AutoLot.Samples.Models

{

  public class Car : BaseEntity

  {

    public string Color { get; set; }

    public string PetName { get; set; }

    public int MakeId { get; set; }

    public Make MakeNavigation { get; set; }

    public Radio RadioNavigation { get; set; }

<b>    public IEnumerable&lt;Driver&gt; Drivers { get; set; } = new List&lt;Driver&gt;();</b>

  }

}

namespace AutoLot.Samples.Models

{

  public class Driver : BaseEntity

  {

    public string FirstName { get; set; }

    public string LastName { get; set; }

<b>    public IEnumerable&lt;Car&gt; Cars { get; set; } = new List&lt;Car&gt;();</b>

  }

}

Эквивалентное решение можно обеспечить путем явного создания трех таблиц и именно так приходилось поступать в версиях EF Core, предшествующих EF Core 5. Вот как выглядит сокращенный пример:

public class Driver

{

  ...

<b>  public IEnumerable&lt;CarDriver&gt; CarDrivers { get; set; }</b>

}

public class Car

{

  ...

<b>  public IEnumerable&lt;CarDriver&gt; CarDrivers { get; set; }</b>

}

public class CarDriver

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

{

  public int CarId {get;set;}

<b>  public Car CarNavigation {get;set;}</b>

  public int DriverId {get;set;}

<b>  public Driver DriverNavigation {get;set;}</b>

}

Добавьте в класс ApplicationDbContext экземпляр DbSet&lt;Driver&gt;:

public virtual DbSet&lt;Car&gt; Cars { get; set; }

public virtual DbSet&lt;Make&gt; Makes { get; set; }

<b>public virtual DbSet&lt;Radio&gt; Radios { get; set; }</b>

<b>public virtual DbSet&lt;Driver&gt; Drivers { get; set; }</b>

Создайте миграцию и обновите базу данных с помощью следующих команд:

dotnet ef migrations add Many2Many -o Migrations

 -c AutoLot.Samples.ApplicationDbContext

dotnet ef database update many2Many  -c AutoLot.Samples.ApplicationDbContext

После обновления базы данных с применением миграции EF Core таблица Cars не изменяется, но создаются таблицы Drivers и CarDriver:

CREATE TABLE [dbo].[Drivers](

  [Id] [INT] IDENTITY(1,1) NOT NULL,

  [FirstName] [NVARCHAR](MAX) NULL,

  [LastName] [NVARCHAR](MAX) NULL,

  [TimeStamp] [VARBINARY](MAX) NULL,

 CONSTRAINT [PK_Drivers] PRIMARY KEY CLUSTERED

(

  [Id] ASC

)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF,

 IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON,

 OPTIMIZE_FOR_SEQUENTIAL_KEY = OFF) ON [PRIMARY]

) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY]

GO

CREATE TABLE [dbo].[CarDriver](

  [CarsId] [int] NOT NULL,

  [DriversId] [int] NOT NULL,

 <b>CONSTRAINT [PK_CarDriver] PRIMARY KEY CLUSTERED</b>

<b>(</b>

<b>  [CarsId] ASC,</b>

<b>  [DriversId] ASC</b>

<b>)</b>WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF,

 IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON,

Перейти на страницу:
Комментариев (0)