我在客户端和地址之间建立了一对一的关系。根据我的理解,我必须修改我所拥有的OnModelCreating
方法。现在我准备好了我的应用程序,但我需要正确初始化我的数据库;但是我收到了错误。
主要计划是先创建一个客户端,然后再创建一个与之关联的地址。
这是我的上下文类:
public class VolumeV2Context : DbContext
{
public DbSet<GiftCard> GiftCards { get; set; }
public DbSet<Clients> Clients { get; set; }
public DbSet<Address> Address { get; set; }
// use if you need to drop the database
static VolumeV2Context(){
// use if need to reset the models
// Database.SetInitializer(new DropCreateDatabaseIfModelChanges<VolumeV2Context>());
// use to reset whole database tables
Database.SetInitializer(new DropCreateDatabaseAlways<VolumeV2Context>());
}
protected override void OnModelCreating(System.Data.Entity.DbModelBuilder modelBuilder)
{
modelBuilder.Entity<Clients>()
.HasOptional(j => j.Address)
.WithOptionalDependent()
.WillCascadeOnDelete(true);
modelBuilder.Entity<Address>()
.HasRequired(j => j.client)
.WithRequiredDependent()
.WillCascadeOnDelete(true) ;
base.OnModelCreating(modelBuilder);
}
}
模型
public class Address
{
[Required]
public int Id { get; set; }
[DataType(DataType.Text)]
[Display(Name = "Street Address")]
public string StreetAddress { get; set; }
[DataType(DataType.Text)]
[Display(Name = "Postal Code")]
public string PostalCode { get; set; }
[DataType(DataType.Text)]
public string City {get; set; }
[DataType(DataType.Text)]
public string Province {get; set;}
public virtual Clients client { get; set; }
}
public class Clients
{
[Required]
public long Id { get; set; }
[Required]
[DataType(DataType.Text)]
[Display(Name = "First Name")]
public string FirstName { get; set; }
[Required]
[DataType(DataType.Text)]
[Display(Name = "Last Name")]
public string LastName { get; set; }
[Required]
[DataType(DataType.PhoneNumber)]
[Display(Name = "Phone ")]
public string PhoneNumber { get; set; }
public virtual Address Address {get; set;}
[Display(Name = "Email List")]
public Boolean EmailList { get; set; }
[DataType(DataType.EmailAddress)]
[Display(Name = "E-mail")]
public string Email { get; set; }
[DataType(DataType.Text)]
[Display(Name = "Hair Type")]
public string HairType { get; set; }
[DataType(DataType.MultilineText)]
public string Description { get; set; }
}
在我第一次调用数据库时,它位于主索引方法
中return View(db.Clients.Take(25).ToList());
它返回错误说:
引入FOREIGN KEY约束 &#39; FK_dbo.Addresses_dbo.Clients_client_Id&#39;在桌子上&#39;地址&#39;可以 导致循环或多个级联路径。指定ON DELETE NO ACTION或 ON UPDATE NO ACTION,或修改其他FOREIGN KEY约束。可以 不创造约束。查看以前的错误。
答案 0 :(得分:3)
问题是你有双向级联删除。换句话说,删除客户端将删除将删除将删除地址的客户端的地址...您将获得图片。
只看你的数据模型,如果他/她的地址被删除(人们一直移动:-)),删除客户端会不会更有意义 not 。或者有没有理由为什么删除地址也应该消灭客户端(毕竟,你的数据模型确实说地址是可选的......)
如果你注释掉这些行:
modelBuilder.Entity<Address>()
.HasRequired(j => j.client)
.WithRequiredDependent()
.WillCascadeOnDelete(true) ;
,或者将WillCascadeOnDelete设为false,是否有效?
另一种选择是完全关闭级联删除约定...
modelBuilder.Conventions.Remove<OneToManyCascadeDeleteConvention>();
但我认为这不是你想要做的......