![](/img/trans.png)
[英]Entity Framework Code First: How can I create a One-to-Many AND a One-to-One relationship between two tables?
[英]How to create nullable one-to-many relationship in Entity Framwork 6 code first
我首先使用 EF 6.1 代码构建应用程序。 实体模型包含以下类:
public enum UnitSystem {
English,
Metric
}
public enum UnitTypes {
Volume,
Weight,
Other
}
public class Unit {
[DatabaseGenerated( DatabaseGeneratedOption.Identity ), Key]
public int UnitId { get; set; }
[Required, MaxLength( 128 ), Index( IsUnique = true )]
public string UnitName { get; set; }
[Required]
public UnitSystem UnitSystem { get; set; }
[Required]
public UnitTypes UnitType { get; set; }
public virtual ICollection<Item> Items { get; set; }
}
public class Item {
[DatabaseGenerated( DatabaseGeneratedOption.Identity ), Key]
public int ItemId { get; set; }
[Required, MaxLength( 128 ), Index( IsUnique = true )]
public string ItemName { get; set;
[Required]
public int UnitId { get; set; }
[ForeignKey( "UnitId" )]
public virtual Unit Units { get; set; }
/// Other unimportant properties
}
public class UnitConversion {
[Required, Key, Column( Order = 0 )]
public int FromUnitId { get; set; }
[ForeignKey( "FromUnitId" )]
public virtual Unit FromUnit { get; set; }
[Required, Key, Column( Order = 1)]
public int ToUnitId { get; set; }
[ForeignKey( "ToUnitId" )]
public virtual Unit ToUnit { get; set; }
[Key, Column( Order = 2 )]
public int? ItemId { get; set; }
public virtual Item Item { get; set; }
[Required]
public double ConversionFactor { get; set; }
}
当 EF 构建数据库时,我收到“Introducing FOREIGN KEY CONSTRAINT”消息。 我需要ItemId
属性可以为空,如果它不为空,我需要它是Items
表的外键。
创建这种关系以避免级联删除错误的正确方法是什么?
编辑
我不再在ItemId
列上收到错误消息; 现在我为FromUnitId
或ToUnitId
列或两者都得到它。
我已经向Unit
类添加了导航属性:
[ForeignKey("FromUnitId")]
public virtual ICollection<UnitConversion> FromConversions { get; set; }
[ForeignKey("ToUnitId")]
public virtual ICollection<UnitConversion> ToConversions { get; set; }
这是我收到的错误消息的全文:
在表“UnitConversions”上引入 FOREIGN KEY 约束“FK_dbo.UnitConversions_dbo.Units_ToUnitId”可能会导致循环或多个级联路径。 指定 ON DELETE NO ACTION 或 ON UPDATE NO ACTION,或修改其他 FOREIGN KEY 约束。
UnitConversions
表和Units
表之间应该存在零或一对多的关系。 当我尝试创建对modelBuiloder.Entity<UnitConversions>().WillCascadeOnDelete(false)
的调用时,IntelliSense 不显示WillCascadeOnDelete
方法,并且代码不会编译。
首先,我建议您快速阅读entityframeworktutorial以确保您按照建议设置了密钥。 对于 1 对 1 的关系,这有点棘手; 基本上'Child'的主键是'Parent'的外键。
或者,您可以在数据上下文中使用 fluent API 并执行以下操作以确保关系和级联按预期进行:
protected override void OnModelCreating(DbModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<Student>().HasOptional(e => e.StudentAddress)
.WithRequired(m => m.Student);
modelBuilder.Entity<StudentAddress>.WillCascadeOnDelete(false);
}
这表示学生有一个可选的学生地址,学生地址有一个必需的学生,当学生地址被删除时,学生不是。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.