ASP.Net MVC 3アプリケーションを作成していますが、移行を使用してデータベースを更新しようとすると、外部キー制約の問題が発生します。私はCode-Firstを使用していますが、発生するエラーは次のとおりです。
テーブル'CategoryItemValues'にFOREIGNKEY制約'FK_CategoryItemValues_CategoryProperties_CategoryPropertyId'を導入すると、サイクルまたは複数のカスケードパスが発生する可能性があります。ON DELETENOACTIONまたはONUPDATENO ACTIONを指定するか、他のFOREIGNKEY制約を変更します。制約を作成できませんでした。以前のエラーを参照してください。
これが私のクラスです:
public class Category
{
public int Id { get; set; }
[Display(Name = "Category Name")]
public string CategoryName { get; set; }
[Display(Name = "Display Name")]
public string DisplayName { get; set; }
[Display(Name = "Display Order")]
public int DisplayOrder { get; set; }
public bool IsTab { get; set; }
public bool Active { get; set; }
public virtual List<CategoryProperty> Properties { get; set; }
}
public class CategoryProperty
{
public int Id { get; set; }
public int CategoryId { get; set; }
[Display(Name="Property Name")]
public string PropertyName { get; set; }
[Display(Name = "Display Order")]
public int DisplayOrder { get; set; }
public virtual Category Category { get; set; }
}
public class CategoryItem
{
public int Id { get; set; }
public int CategoryId { get; set; }
public virtual Category Category { get; set; }
public virtual List<CategoryItemValue> Values { get; set; }
}
public class CategoryItemValue
{
public int Id { get; set; }
public int CategoryItemId { get; set; }
public int CategoryPropertyId { get; set; }
public string Value { get; set; }
public virtual CategoryItem Item { get; set; }
public virtual CategoryProperty Property { get; set; }
}
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
// I know that the solution needs to go here!
}
CategoryItemValuesの削除時にカスケードを無効にする必要があるようですが、その方法がわかりません。私は次のようなことをする必要があることを知っています:
modelBuilder.Entity <...>().HasRequired(...).WithMany(...).HasForeignKey(...).WillCascadeOnDelete(false);
しかし、私はそれを正確に理解することはできません。