许可优化
许可优化
产品
产品
解决方案
解决方案
服务支持
服务支持
关于
关于
软件库
当前位置:服务支持 >  软件文章 >  使用Fluent API配置/映射实体属性和类型(第二部分)

使用Fluent API配置/映射实体属性和类型(第二部分)

阅读数 3
点赞 0
article_banner

1.将多个实体类映射到数据库中的一个表

  要将多个实体映射到一个数据库表需要满足:

  a. 两个实体必须是一对一关系

  b.两个实体共享一个主键


 1  public  class MyContext:DbContext
 2     {
 3         public MyContext()
 4             : base("test")
 5         { }
 6         protected override void OnModelCreating(DbModelBuilder modelBuilder)
 7         {
 8             modelBuilder.Entity<Person>()
 9                 .HasRequired(p => p.Detail)
10                 .WithRequiredPrincipal();
11         }
12         public DbSet<Person> Persons { get; set; }
13         public DbSet<PersonDetail> PersonDetails { get; set; }
14 
15     }
16 
17     [Table("Person")]
18     public class Person
19     {
20         public int Id { get; set; }
21         public string Name { get; set; }
22         public bool Sex { get; set; }
23         public PersonDetail Detail { get; set; }
24     }
25     [Table("Person")]
26     public class PersonDetail
27     {
28         [Key,ForeignKey("Person")]
29         public int Id { get; set; }
30         public DateTime Birth { get; set; }
31         public byte[] Photo { get; set; }
32         public Person Person { get; set; }
33     }
34 }View Code

2.将实体类型的 CLR 属性映射到数据库中的多个表


 1  public  class MyContext:DbContext
 2     {
 3         public MyContext()
 4             : base("test")
 5         { }
 6         protected override void OnModelCreating(DbModelBuilder modelBuilder)
 7         {
 8             modelBuilder.Entity<Person>()
 9                 .Map(p =>
10                 {
11                     p.Properties(t => new { t.Id, t.Name, t.Sex });
12                     p.ToTable("Person");
13                 })
14                 .Map(p =>
15                 {
16                     p.Properties(t => new { t.Birth, t.Photo });
17                     p.ToTable("PersonDetails2");
18                 }
19                 );
20         }
21         public DbSet<Person> Persons { get; set; } 
22     }
23 
24     [Table("Person")]
25     public class Person
26     {
27         public int Id { get; set; }
28         public string Name { get; set; }
29         public bool Sex { get; set; }  
30         public DateTime Birth { get; set; }
31         public byte[] Photo { get; set; }
32     }View Code

转载于:https://www.cnblogs.com/goodlucklzq/p/4612060.html


免责声明:本文系网络转载或改编,未找到原创作者,版权归原作者所有。如涉及版权,请联系删


相关文章
技术文档
QR Code
微信扫一扫,欢迎咨询~
customer

online

联系我们
武汉格发信息技术有限公司
湖北省武汉市经开区科技园西路6号103孵化器
电话:155-2731-8020 座机:027-59821821
邮件:tanzw@gofarlic.com
Copyright © 2023 Gofarsoft Co.,Ltd. 保留所有权利
遇到许可问题?该如何解决!?
评估许可证实际采购量? 
不清楚软件许可证使用数据? 
收到软件厂商律师函!?  
想要少购买点许可证,节省费用? 
收到软件厂商侵权通告!?  
有正版license,但许可证不够用,需要新购? 
联系方式 board-phone 155-2731-8020
close1
预留信息,一起解决您的问题
* 姓名:
* 手机:

* 公司名称:

姓名不为空

姓名不为空

姓名不为空
手机不正确

手机不正确

手机不正确
公司不为空

公司不为空

公司不为空