Удалить каскадный метод в таблице с двумя внешними ключами из другой таблицы ENTITY framework - PullRequest
0 голосов
/ 09 апреля 2020

Entity Framework не позволяет мне выполнить эту миграцию (см. Ниже). Это говорит о том, что удаление каскада может вызвать циклы или несколько путей каскада. У меня есть стол со стопами и стол с ногами. Каждая нога имеет две остановки (начало и конец sh). Я предполагаю, что Entity Framework пытается сказать, что если у меня есть нога с двумя подобными остановками, и я пытаюсь удалить эту остановку, то Entity удалит остановку, а не ногу, а затем попытается удалить уже остановленную остановку. удалено (цикл). Сначала я просто удалил "cascadeDelete: true". И запустил миграцию. Но теперь у меня есть другая проблема. Я не могу удалить остановку, потому что таблица ног имеет ссылку на эту остановку. Я предполагаю, что у меня плохая схема базы данных. Не могли бы вы дать мне совет, как это исправить в платформе Entity? (некоторый двойной внешний ключ с двумя остановками) Как я могу изменить миграцию ниже?

public class Leg
    {
        public int Id { get; set; }
        public int Stop1Id { get; set; }
        public Stop Stop1 { get; set; }
        public int Stop2Id { get; set; }
        public Stop Stop2 { get; set; }
        public int DriverId { get; set; }
        public Driver Driver { get; set; }
        public int LoadConfirmationId { get; set; }
        public LoadConfirmation LoadConfirmation { get; set; }
    }

    public partial class AddLegs : DbMigration
        {
            public override void Up()
            {
                CreateTable(
                    "dbo.Legs",
                    c => new
                        {
                            Id = c.Int(nullable: false, identity: true),
                            Stop1Id = c.Int(nullable: false),
                            Stop2Id = c.Int(nullable: false),
                            DriverId = c.Int(nullable: false),
                        })
                    .PrimaryKey(t => t.Id)
                    .ForeignKey("dbo.Drivers", t => t.DriverId, cascadeDelete: true)
                    .ForeignKey("dbo.Stops", t => t.Stop1Id, cascadeDelete: true)
                    .ForeignKey("dbo.Stops", t => t.Stop2Id, cascadeDelete: true)
                    .Index(t => t.Stop1Id)
                    .Index(t => t.Stop2Id)
                    .Index(t => t.DriverId);

            }

            public override void Down()
            {
                DropForeignKey("dbo.Legs", "Stop2Id", "dbo.Stops");
                DropForeignKey("dbo.Legs", "Stop1Id", "dbo.Stops");
                DropForeignKey("dbo.Legs", "DriverId", "dbo.Drivers");
                DropIndex("dbo.Legs", new[] { "DriverId" });
                DropIndex("dbo.Legs", new[] { "Stop2Id" });
                DropIndex("dbo.Legs", new[] { "Stop1Id" });
                DropTable("dbo.Legs");
            }
        }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...