网站首页 > 技术教程 正文
1 entityframwor是.net的orm组件(以下简称EF),基本上集成了orm所有功能之大成,并且开创了linq语法,使用lambda表达式对数据进行处理,在编程语言界可谓独领风骚,用来写后台不要太爽,用过都知道。
2 什么是导航属性呢?其实就是sql的子表关系在面向对象关系里的属性映射。在后台开发的数据处理中,多表关联查询是最最最常见的,但这却是orm里最难搞定的问题,不过EF使用一个称为Navigation(导航)的方式完美解决。 简单说比如表a{id,name }是主表,b{id,a_id,name}是子表,一对多的关系,a_id是b关联a的外键。很常见。在EF的实体里这样定义:
public class A
{
[Key]
public int ID { get; set; }
}
public class B
{
[Key]
public int ID { get; set; }
public int A_ID { get; set; }
[ForeignKey("A_ID")]
public A A { get; set; }
}当b需要引用时a用include方法把a加载进来就行了。如
var list =DbContext.B.include(p=>p.A);
反过来,当a需要加载子表b的所有数据时,可以这样定义实体
public class A
{
[Key]
public int ID { get; set; }
public List<B> ListB { get; set; }
}
public class B
{
[Key]
public int ID { get; set; }
public int A_ID { get; set; }
[ForeignKey("A_ID")]
public A A { get; set; }
}同样用include方法把b加载进来就行了,如
var list =DbContext.A.where(p=>p.Name=="张三").include(p=>p.ListB).ToList();
3 导航是支持链表关系的,即可以无限制传递下去,当然现实中没人这样设计,一般关联到四五层关系。假设a和b有外键关联,b和c也有外键关联,那么c在加载数据时就可以写成
DbContext.C.Include(p=>p.B).ThenInclude(p=>p.A)
4 还有一种更加复杂的情况。即b有两个外键都是关联到a表。比如老师表 techer{id,姓名...},学生表 student{id,数学老师id,语文老师id...} 实体定义如下
public class Teacher
{
[Key]
public int ID { get; set; }
public string Name { get; set; }
public List<Student> Students { get; set; }
}
public class Student
{
[Key]
public int ID { get; set; }
public int Teacher_Yuwen_ID { get; set; }
[ForeignKey("Teacher_ID")]
public Teacher Yuwen { get; set; }
public int Teacher_Shuxue_ID { get; set; }
[ForeignKey("Teacher_Shuxue_ID")]
public Teacher Shuxue { get; set; }
}那么,当teacher需要加载students时,如何指定关联外键是Teacher_Yuwen_ID 还是Teacher_Shuxue_ID呢?那就需要在DbContext初始化时指定一个。
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Teacher>().HasMany(p => p.Students).WithOne(p=>p.Yuwen);
}
猜你喜欢
- 2024-10-30 Spring Boot中RestTemplate开发实践(2)
- 2024-10-30 Entity Framework Core-删除数据(怎么删除framework4.0)
- 2024-10-30 EntityFramework Core 2.x/3.x (ef core) 在迁移中自动生成数据库表
- 2024-10-30 Entity Framework Core-使用Fluent API配置一对多关系
- 2024-10-30 .NET 7使用 Entity Framework Core 制作增删改查(CRUD) Web API 教程
- 2024-10-30 今日技术点:使用Entity Framework Core进行数据库迁移
- 2024-10-30 .Net Core下多种ORM框架特性及性能对比
- 2024-10-30 Entity Framework 7 支持批量操作和 JSON 列
- 2024-10-30 Entity Framework Core-Fluent API
- 2024-10-30 Entity Framework Core中 如何加缓存处理?
欢迎 你 发表评论:
- 10-23Excel计算工龄和年份之差_excel算工龄的公式year
- 10-23Excel YEARFRAC函数:时间的"年份比例尺"详解
- 10-23最常用的10个Excel函数,中文解读,动图演示,易学易用
- 10-23EXCEL中如何计算截止到今日(两个时间中)的时间
- 10-2390%人不知道的Excel神技:DATEDIF 精准计算年龄,告别手动算错!
- 10-23计算工龄及工龄工资(90%的人搞错了):DATE、DATEDIF组合应用
- 10-23Excel中如何计算工作日天数?用这两个函数轻松计算,附新年日历
- 10-23怎样快速提取单元格中的出生日期?用「Ctrl+E」批量搞定
- 最近发表
-
- Excel计算工龄和年份之差_excel算工龄的公式year
- Excel YEARFRAC函数:时间的"年份比例尺"详解
- 最常用的10个Excel函数,中文解读,动图演示,易学易用
- EXCEL中如何计算截止到今日(两个时间中)的时间
- 90%人不知道的Excel神技:DATEDIF 精准计算年龄,告别手动算错!
- 计算工龄及工龄工资(90%的人搞错了):DATE、DATEDIF组合应用
- Excel中如何计算工作日天数?用这两个函数轻松计算,附新年日历
- 怎样快速提取单元格中的出生日期?用「Ctrl+E」批量搞定
- Excel日期函数之DATEDIF函数_excel函数datedif在哪里
- Excel函数-DATEDIF求司龄_exceldatedif函数计算年龄
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)

本文暂时没有评论,来添加一个吧(●'◡'●)