エンティティフレームワークの親 - >子リンクと外部キーの制約に失敗しました

c# entity-framework-core foreign-key-relationship sqlite

質問

私はエンティティフレームワーク7(コア)とSqliteデータベースを使用しています。現在このメソッドでエンティティカテゴリを変更するためにcomboBoxを使用しています:

/// <summary>
/// Changes the given device gategory.
/// </summary>
/// <param name="device"></param>
/// <param name="category"></param>
public bool ChangeCategory(Device device, Category category)
{
    if (device != null && category != null )
    {
        try
        {
            var selectedCategory = FxContext.Categories.SingleOrDefault(s => s.Name == category.Name);
            if (selectedCategory == null) return false;
            if (device.Category1 == selectedCategory) return true;

            device.Category1 = selectedCategory;
            device.Category = selectedCategory.Name;
            device.TimeCreated = DateTime.Now;
            return true;
        }
        catch (Exception ex)
        {
            throw new InvalidOperationException("Category change for device failed. Possible reason: database has multiple categories with same name.");
        }
    }
    return false;
}

この関数は、 deviceカテゴリIDをうまく変更します。しかし、これは正しい方法ですか?

リンクした後、このcategoryを削除している間に、Sqliteデータベースからエラーが発生します。

{"SQLiteエラー19: 'FOREIGN KEY制約に失敗しました'"}

カテゴリ削除メソッド

public bool RemoveCategory(Category category)
{
    if (category == null) return false;
    var itemForDeletion = FxContext.Categories
        .Where(d => d.CategoryId == category.CategoryId);
    FxContext.Categories.RemoveRange(itemForDeletion);
    return true;
}

EDIT devicecategory構造を以下に示しcategory

CREATE TABLE "Category" (
    "CategoryId" INTEGER NOT NULL CONSTRAINT "PK_Category" PRIMARY KEY AUTOINCREMENT,
    "Description" TEXT,
    "HasErrors" INTEGER NOT NULL,
    "IsValid" INTEGER NOT NULL,
    "Name" TEXT
)

CREATE TABLE "Device" (
    "DeviceId" INTEGER NOT NULL CONSTRAINT "PK_Device" PRIMARY KEY AUTOINCREMENT,
    "Category" TEXT,
    "Category1CategoryId" INTEGER,
    CONSTRAINT "FK_Device_Category_Category1CategoryId" FOREIGN KEY ("Category1CategoryId") REFERENCES "Category" ("CategoryId") ON DELETE RESTRICT,
)

受け入れられた回答

SQLiteテーブルには、 ON DELETE RESTRICT外部キーの制限があります。つまり、デバイスの行が削除しようとしているカテゴリを指している場合、SQLiteデータベースはこの操作を禁止します。これを回避するには、(1)明示的にすべてのデバイスを別のカテゴリに変更するか、または(2)ON DELETE動作をCASCADESET NULLなどの別のものに変更しSET NULLhttps://www.sqlite.org/foreignkeys.html#fk_actionsを参照してください。

EFを使用して表を作成した場合は、削除時に別の動作を使用するようにモデルを構成します。デフォルトはrestrictです。 https://docs.efproject.net/en/latest/modeling/relationships.html#id2を参照してください 。例:

        modelBuilder.Entity<Post>()
            .HasOne(p => p.Blog)
            .WithMany(b => b.Posts)
            .OnDelete(DeleteBehavior.Cascade);


Related

ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ
ライセンスを受けた: CC-BY-SA with attribution
所属していない Stack Overflow
このKBは合法ですか? はい、理由を学ぶ