acc*_*der 5 entity-framework ef-code-first ef-migrations
为什么在配置中定义与WillCascadeOnDelete(false)的关系在生成的迁移中始终为真?
这是配置代码
public class PartySuppliesConfiguration:EntityTypeConfiguration<PartySupplies>
{
public PartySuppliesConfiguration()
{
HasKey(x => x.Id);
HasRequired(x=>x.Supplier).WithMany().HasForeignKey(x=>x.SupplierId).WillCascadeOnDelete(false);
HasRequired(x => x.Product).WithMany().HasForeignKey(x => x.ProductId).WillCascadeOnDelete(false);
HasRequired(x => x.Currency).WithMany().HasForeignKey(x => x.CurrencyId).WillCascadeOnDelete(false);
HasRequired(x => x.CreatedUser).WithMany().HasForeignKey(x => x.CreatedUserId).WillCascadeOnDelete(false);
Property(x => x.UnitPrice).HasColumnType("Money");
}
}
Run Code Online (Sandbox Code Playgroud)
这是生成的迁移
public override void Up()
{
CreateTable(
"PartySupplies",
c => new
{
Id = c.Int(nullable: false, identity: true),
SupplierId = c.Int(nullable: false),
ProductId = c.Int(nullable: false),
UnitPrice = c.Decimal(nullable: false, precision: 18, scale: 2),
CurrencyId = c.Int(nullable: false),
FromDate = c.DateTime(nullable: false),
ThruDate = c.DateTime(),
CreatedUserId = c.Int(nullable: false),
})
.PrimaryKey(t => t.Id)
.ForeignKey("Parties", t => t.SupplierId, cascadeDelete: true)
.ForeignKey("Products", t => t.ProductId, cascadeDelete: true)
.ForeignKey("Curencies", t => t.CurrencyId, cascadeDelete: true)
.ForeignKey("Users", t => t.CreatedUserId, cascadeDelete: true)
.Index(t => t.SupplierId)
.Index(t => t.ProductId)
.Index(t => t.CurrencyId)
.Index(t => t.CreatedUserId);
}
Run Code Online (Sandbox Code Playgroud)
小智 1
这可能是一个愚蠢的问题,但您是否重写了 DbContext 中的 OnModelBuilding 方法并添加了modelBuilder.Configurations.Add( new PartySuppliesConfiguration( ) );?是否PartySuppliers有任何可能覆盖您的实体配置类的 DataAnnotations?或者也许它是从另一个级联删除设置为 true 的类派生的?
| 归档时间: |
|
| 查看次数: |
2049 次 |
| 最近记录: |