Язык программирования C#9 и платформа .NET5 - Троелсен Эндрю
namespace AutoLot.Dal.EfStructures.Migrations
{
public partial class SQL : Migration
{
protected override void Up(MigrationBuilder migrationBuilder)
{
<b> MigrationHelpers.CreateSproc(migrationBuilder);</b>
<b> MigrationHelpers.CreateCustomerOrderView(migrationBuilder);</b>
}
protected override void Down(MigrationBuilder migrationBuilder)
{
<b> MigrationHelpers.DropSproc(migrationBuilder);</b>
<b> MigrationHelpers.DropCustomerOrderView(migrationBuilder);</b>
}
}
}
Если вы удалили свою базу данных, чтобы запустить начальную миграцию, тогда можете применить эту миграцию и двигаться дальше. Примените миграцию, выполнив следующую команду:
dotnet ef database update -c AutoLot.Dal.EfStructures.ApplicationDbContext
если вы не удаляли свою базу данных для первой миграции, то процедура уже существует и не может быть снова создана. В таком случае легче всего закомментировать в методе
Up()
protected override void Up(MigrationBuilder migrationBuilder)
{
// MigrationHelpers.CreateSproc(migrationBuilder);
MigrationHelpers.CreateCustomerOrderView(migrationBuilder);
}
После применения полученной миграции в первый раз уберите комментарий с указанной выше строки и все будет работать нормально. Разумеется, можно поступить и по-другому: удалить хранимую процедуру из базы данных и затем применить миграцию. В итоге нарушится парадигма "одно место для обновлений", но это часть перехода со способа "сначала база данных" на способ "сначала код".
На заметку! Вы также могли бы написать код, который сначала проверяет, существует ли объект, и в таком случае удаляет его, но это уже излишество для проблемы, которая возможно никогда не возникнет.
Добавление модели представления
Теперь, когда представление SQL Server на месте, самое время создать модель представления, которая будет использоваться для отображения данных из представления. Модель представления будет добавлена как
DbSet<T>
DbSet<T>
Добавление класса модели представления
Добавьте в проект
AutoLot.Models
ViewModels
CustomerOrderViewModel.cs
using
using System.ComponentModel.DataAnnotations.Schema;
using Microsoft.EntityFrameworkCore;
Приведите код к следующему виду:
namespace AutoLot.Models.ViewModels
{
[Keyless]
public class CustomerOrderViewModel
{
public string? FirstName { get; set; }
public string? LastName { get; set; }
public string? Color { get; set; }
public string? PetName { get; set; }
public string? Make { get; set; }
public bool? IsDrivable { get;set; }
[NotMapped]
public string FullDetail =>
$"{FirstName} {LastName} ordered a {Color} {Make} named {PetName}";
public override string ToString() => FullDetail;
}
}
Аннотация данных
[KeyLess]
FullDetail
[NotMapped]
ToString()
Добавление класса модели представления к ApplicationDbContext
Финальный шаг предусматривает регистрацию и конфигурирование
CustomerOrderViewModel
ApplicationDbContext
Добавьте к
ApplicationDbContext
using
AutoLot.Models.ViewModels
DbSet<T>
public virtual DbSet<CustomerOrderViewModel>?
CustomerOrderViewModels { get; set; }
Помимо добавления свойства
DbSet<T>
HasNoKey()
[KeyLess]
OnModelCreating()