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; }

    public IEnumerable Drivers { get; set; } = new List();

  }

}

namespace AutoLot.Samples.Models

{

  public class Driver : BaseEntity

  {

    public string FirstName { get; set; }

    public string LastName { get; set; }

    public IEnumerable Cars { get; set; } = new List();

  }

}

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

public class Driver

{

  ...

  public IEnumerable CarDrivers { get; set; }

}

public class Car

{

  ...

  public IEnumerable CarDrivers { get; set; }

}

public class CarDriver

{

  public int CarId {get;set;}

  public Car CarNavigation {get;set;}

  public int DriverId {get;set;}

  public Driver DriverNavigation {get;set;}

}

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

public virtual DbSet Cars { get; set; }

public virtual DbSet Makes { get; set; }

public virtual DbSet Radios { get; set; }

public virtual DbSet Drivers { get; set; }

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

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,

 CONSTRAINT [PK_CarDriver] PRIMARY KEY CLUSTERED

(

  [CarsId] ASC,

  [DriversId] 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]

GO

ALTER TABLE [dbo].[CarDriver]

WITH CHECK ADD  CONSTRAINT [FK_CarDriver_Cars_CarsId] FOREIGN

KEY([CarsId])

REFERENCES [dbo].[Cars] ([Id])

ON DELETE CASCADE

GO

ALTER TABLE [dbo].[CarDriver] CHECK CONSTRAINT [FK_CarDriver_Cars_CarsId]

GO

ALTER TABLE [dbo].[CarDriver]

WITH CHECK ADD  CONSTRAINT [FK_CarDriver_Drivers_DriversId]

FOREIGN KEY([DriversId])

REFERENCES [dbo].[Drivers] ([Id])

ON DELETE CASCADE

GO

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

Похожие книги