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

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

Наш ресурс дает возможность бесплатно читать книгу онлайн Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю. Жанр: Базы данных . Сайт books-read.com дает возможность читать полную версию книги без регистрации и sms. Все книги онлайн, не надо качать fb2, epub, txt.
Добавить книгу Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю в приложение ЧИТАТЬ КНИГУ ОФЛАЙН в приложении ios/android
Перейти на страницу:

    case EntityState.Unchanged:

      action = e.OldState switch

      {

        EntityState.Added => "Added",

        EntityState.Modified => "Edited",

        _ => action

      };

      Console.WriteLine($"The object was {action}");

      break;

  }

}

Создание миграции и обновление базы данных

На этой стадии оба проекта компилируются и все готово к созданию еще одной миграции для обновления базы данных. Введите в каталоге проекта

AutoLot.Dal
следующие команды (каждая команда должна вводиться в одной строке):

dotnet ef migrations add UpdatedEntities -o EfStructuresMigrations

 -c AutoLot.Dal.
EfStructures.ApplicationDbContext

dotnet ef database update UpdatedEntities

 -c AutoLot.Dal.EfStructures.ApplicationDbContext

Добавление представления базы данных и хранимой процедуры

 Осталось внести в базу данных два изменения: создать хранимую процедуру

GetPetName
, рассмотренную в главе 21, и добавить представление базы данных, которое объединяет таблицу
Orders
с деталями
Customer
,
Car
и
Make
.

Добавление класса MigrationHelpers

Хранимая процедура и представление будут создаваться с использованием миграции, которая требует написания кода вручную. Причина поступать так (вместо того, чтобы просто открыть Azure Data Studio и запустить код T-SQL) — желание поместить полное конфигурирование базы данных в один процесс. Когда все содержится в миграциях, единственный вызов

dotnet ef database update
гарантирует, что база данных является актуальной, включая конфигурацию EF Core и специальный код SQL.

Выполнение команды

the dotnet ef migrations add
при отсутствии изменений в модели все равно приводит к созданию файлов миграции, имеющих правильную отметку времени, с пустыми методами
Up()
и
Down()
. Введите показанную ниже команду для создания пустой миграции (но не применения миграции):

dotnet ef migrations add SQL -o EfStructuresMigrations

 -c AutoLot.Dal.EfStructures.
ApplicationDbContext

Создайте в каталоге

EfStructures
проекта
AutoLot.Dal
новый файл по имени
MigrationHelpers.cs
. Добавьте оператор
using
для пространства имен
Microsoft.EntityFrameworkCore.Migrations
, сделайте класс открытым и статическим и поместите в него следующие методы, которые используют
MigrationBuilder
для запуска операторов SQL в отношении базы данных:

namespace AutoLot.Dal.EfStructures

{

  public static class MigrationHelpers

  {

    public static void CreateSproc(MigrationBuilder migrationBuilder)

    {

      migrationBuilder.Sql($@"

          exec (N'

          CREATE PROCEDURE [dbo].[GetPetName]

              @carID int,

              @petName nvarchar(50) output

          AS

          SELECT @petName = PetName from dbo.Inventory where Id = @carID

      ')");

    }

    public static void DropSproc(MigrationBuilder migrationBuilder)

    {

      migrationBuilder.Sql("DROP PROCEDURE [dbo].[GetPetName]");

    }

    public static void CreateCustomerOrderView(

      MigrationBuilder migrationBuilder)

    {

      migrationBuilder.Sql($@"

          exec (N'

          CREATE VIEW [dbo].[CustomerOrderView]

          AS

      SELECT dbo.Customers.FirstName, dbo.Customers.LastName,

             dbo.Inventory.Color, dbo.Inventory.PetName,

             dbo.Inventory.IsDrivable,

             dbo.Makes.Name AS Make

          FROM dbo.Orders

          INNER JOIN dbo.Customers ON dbo.Orders.CustomerId = dbo.Customers.Id

          INNER JOIN dbo.Inventory ON dbo.Orders.CarId = dbo.Inventory.Id

          INNER JOIN dbo.Makes ON dbo.Makes.Id = dbo.Inventory.MakeId

      ')");

    }

    public static void DropCustomerOrderView(MigrationBuilder migrationBuilder)

    {

      migrationBuilder.Sql("EXEC (N' DROP VIEW [dbo].[CustomerOrderView] ')");

    }

  }

}

Обновление и применение миграции

Для каждого объекта SQL Server в классе

MigrationHelpers
имеется два метода: один создает объект, другой удаляет объект. Вспомните, что при применении миграции выполняется метод
Up()
, а при откате миграции — метод
Down()
. Вызовы статических методов создания должны попасть в метод
Up()
миграции, тогда как вызовы статических методов удаления — в метод
Down()
миграции. В результате применения миграции создаются два объекта SQL Server, которые в случае отката миграции благополучно удаляются. Ниже приведен модифицированный код миграции:

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

Троелсен Эндрю читать все книги автора по порядку

Троелсен Эндрю - на сайте онлайн книг books-read.com Вы можете читать полные версии книг автора в одном месте.


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

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


Уважаемые читатели и просто посетители нашей библиотеки! Просим Вас придерживаться определенных правил при комментировании литературных произведений.

  • 1. Просьба отказаться от дискриминационных высказываний. Мы защищаем право наших читателей свободно выражать свою точку зрения. Вместе с тем мы не терпим агрессии. На сайте запрещено оставлять комментарий, который содержит унизительные высказывания или призывы к насилию по отношению к отдельным лицам или группам людей на основании их расы, этнического происхождения, вероисповедания, недееспособности, пола, возраста, статуса ветерана, касты или сексуальной ориентации.
  • 2. Просьба отказаться от оскорблений, угроз и запугиваний.
  • 3. Просьба отказаться от нецензурной лексики.
  • 4. Просьба вести себя максимально корректно как по отношению к авторам, так и по отношению к другим читателям и их комментариям.

Надеемся на Ваше понимание и благоразумие. С уважением, администратор books-read.com


Прокомментировать
Подтвердите что вы не робот:*