复杂类型是EF Core中用于建模值对象的机制,通过OwnsOne将无主键的类如Address嵌入实体如Order中,默认展平到主表;使用OwnsMany可支持一对多值对象集合,但会创建独立表并外键关联,适用于需结构化存储且无独立标识的场景。

在C#中使用EF Core的复杂类型(Owned Types)是一种将值对象建模为实体一部分的有效方式。它允许你将一个类作为另一个实体的组成部分,而不需要独立的数据库表。
什么是复杂类型(Owned Type)?
复杂类型是EF Core中用于表示“拥有”关系的一种机制。它通常用于表示没有独立标识(即无主键)的值对象。例如,一个Address类可以作为Order或Person的一部分存在,不单独存在表中。
如何定义复杂类型?
要定义一个复杂类型,首先创建一个普通的C#类,然后通过配置告诉EF Core该类是“被拥有的”。
示例:定义Address类作为复杂类型
public class Address{ public string Street { get; set; } public string City { get; set; } public string PostalCode { get; set; } public string Country { get; set; }}
public class Order{ public int Id { get; set; } public string OrderNumber { get; set; } // 这个属性将被映射为复杂类型 public Address ShippingAddress { get; set; }}
如何在DbContext中配置复杂类型?
使用OnModelCreating方法中的OwnsOne来配置复杂类型。
protected override void OnModelCreating(ModelBuilder modelBuilder){ modelBuilder.Entity() .OwnsOne(o => o.ShippingAddress, sa => { sa.Property(a => a.Street).HasColumnName("Shipping_Street"); sa.Property(a => a.City).HasColumnName("Shipping_City"); sa.Property(a => a.PostalCode).HasColumnName("Shipping_PostalCode"); sa.Property(a => a.Country).HasColumnName("Shipping_Country"); });}
说明:
OwnsOne表示该实体拥有一个复杂类型的实例。你可以自定义列名和约束,避免字段名冲突(如多个地址)。默认情况下,EF Core会将所有属性展平到主表中,不会创建新表。
支持集合类型的复杂类型(OwnsMany)
如果你需要一个实体拥有多个复杂类型实例(例如订单有多个收货地址),可以使用OwnsMany。
public class Customer{ public int Id { get; set; } public string Name { get; set; } public List Addresses { get; set; } = new List();}
modelBuilder.Entity() .OwnsMany(c => c.Addresses, a => { a.Property(addr => addr.Street).HasColumnName("Street"); a.Property(addr => addr.City).HasColumnName("City"); // 注意:OwnsMany会在单独的表中存储这些数据 });
注意: OwnsMany虽然也是复杂类型,但EF Core会为其创建单独的表,并通过外键关联,因为它无法展平到单行中。
使用限制和注意事项
复杂类型不能有主键(由EF Core自动管理)。不能被其他实体直接引用(除非也配置为拥有者)。不能被 DbSet 直接查询(不能写context.Set
)。建议将复杂类型设计为不可变或值语义清晰的类。
基本上就这些。只要合理使用OwnsOne和OwnsMany,就能很好地建模领域中的值对象,让数据库结构更清晰。
以上就是C#中如何使用EF Core的复杂类型?如何定义?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1440724.html
微信扫一扫
支付宝扫一扫