c# - asp.net core 2.1中的值对象为无效对象
问题描述
我一直在 asp.net core 2.0 项目中使用值对象,该项目在该项目上运行正常。
我将项目更新到 2.1,它给了我一个错误
Invalid object name 'EntityAdress'.
实体:
public class Company : AuditableEntity<long>
{
public int SalesRepId { get; set; }
public string Name { get; set; }
public int StatusId { get; set; }
public EntityAdress Addresses { get; set; }
public string BillingAddress { get; set; }
}
public class EntityAdress : ValueObject
{
private EntityAdress() { }
public string Address { get; set; }
public string City { get; set; }
public string State { get; set; }
public int Zip { get; set; }
protected override IEnumerable<object> GetAtomicValues()
{
yield return Address;
yield return City;
yield return State;
yield return Zip;
}
}
ValueObject 的实现与值对象的 eshopContainer 示例的链接完全相同
我用于项目的包包含DbContext
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<TargetFramework>netcoreapp2.1</TargetFramework>
<RuntimeFrameworkVersion>2.1.6</RuntimeFrameworkVersion>
</PropertyGroup>
<ItemGroup>
<PackageReference Include="IdentityServer4.AspNetIdentity" Version="1.0.1" />
<PackageReference Include="IdentityServer4.EntityFramework" Version="2.1.1" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Design" Version="2.1.0" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="2.1.0" />
<PackageReference Include="Microsoft.Extensions.Logging" Version="2.1.0" />
<PackageReference Include="Microsoft.Extensions.Configuration.FileExtensions" Version="2.1.0" />
<PackageReference Include="Microsoft.Extensions.Configuration.Json" Version="2.1.0" />
</ItemGroup>
</Project>
语境:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.RemovePluralizingTableNameConvention();
modelBuilder.OnDeleteCascading();
modelBuilder.ApplyConfiguration(new CompanyEntityTypeConfiguraton());
base.OnModelCreating(modelBuilder);
}
公司实体类型配置:
public class CompanyEntityTypeConfiguraton : IEntityTypeConfiguration<Company>
{
public void Configure(EntityTypeBuilder<Company> orderConfiguration)
{
orderConfiguration.OwnsOne(p => p.Addresses, cb =>
{
cb.Property(p => p.City).HasColumnName("City");
cb.Property(p => p.Address).HasColumnName("Address");
cb.Property(p => p.State).HasColumnName("State");
cb.Property(p => p.Zip).HasColumnName("Zip");
});
}
}
OnDeleteCascading 和 RemovePluralizingTableNameConvention:
public static class ModelBuilderExtensions
{
public static void RemovePluralizingTableNameConvention(this ModelBuilder modelBuilder)
{
foreach (IMutableEntityType entity in modelBuilder.Model.GetEntityTypes())
{
entity.Relational().TableName = entity.DisplayName();
}
}
public static void OnDeleteCascading(this ModelBuilder modelBuilder)
{
foreach (var relationship in modelBuilder.Model.GetEntityTypes().SelectMany(e => e.GetForeignKeys()))
{
relationship.DeleteBehavior = DeleteBehavior.Restrict;
}
}
}
问题的原因可能是什么?是实体框架版本的问题还是实现中缺少的东西?
解决方案
EF Core 版本之间的实现总是有一些变化。有些可能是错误修复,这可能导致旧代码以不同方式运行。
问题是这段代码:
public static void RemovePluralizingTableNameConvention(this ModelBuilder modelBuilder)
{
foreach (IMutableEntityType entity in modelBuilder.Model.GetEntityTypes())
{
entity.Relational().TableName = entity.DisplayName();
}
}
首先,您应该排除自有类型(请记住,自有类型仍然是 EF Core 中的实体,因此包含在 中GetEntityTypes()
):
modelBuilder.Model.GetEntityTypes().Where(t => !t.IsOwned())
否则,您将更改 EF Core 默认行为,即不为拥有的实体创建单独的表(所谓的表拆分)以实际创建单独的表,因此当 EF Core 构建 SQL 查询连接到执行的表时会出现异常不存在。
其次,您应该在所有流利的配置之后调用该代码,因为在开始时,拥有的实体(如果未标记[Owned]
属性)尚未被识别 - 它仅在OwnsOne
调用之后发生。
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.ApplyConfiguration(new CompanyEntityTypeConfiguraton());
base.OnModelCreating(modelBuilder);
modelBuilder.RemovePluralizingTableNameConvention();
modelBuilder.OnDeleteCascading();
}
推荐阅读
- shopify - 使用 Shopify rest api 获取 ERR_TOO_MANY_REDIRECTS 失败
- javascript - 如何增加部分大小以适应表格、画廊或大元素?
- reactjs - react-grid-layout 并从外部拖动
- javascript - 使用 Javascript 在页面更改之前完成 CSS 动画
- python - Python 类型提示类作为对象或列表
- asp.net-core - Ubuntu 20.04 上的身份脚手架使用不正确的文件路径 dotnet 5
- c# - 有没有更有效的方法在我的数据库中插入数据数组?Asp.net-core + Dapper
- mysql - 图像未插入 MySQL。错误 1048
- c++ - 宽松的内存顺序自旋锁总是会破坏同步吗?
- rxjs - 在这种情况下,如何使用 rxjs Observable 抛出错误?