网站首页 > 技术教程 正文
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中 如何加缓存处理?
你 发表评论:
欢迎- 最近发表
-
- linux CentOS检查见后门程序的shell
- 网络安全工程师演示:黑客是如何使用Nmap网络扫描工具的?
- Linux中ftp服务修改默认21端口等(linux修改ftp配置文件)
- Linux系统下使用Iptables配置端口转发,运维实战收藏!
- 谈谈TCP和UDP源端口的确定(tcp和udp的端口号相同吗)
- Linux 系统 通过端口号找到对应的服务及相应安装位置
- 快速查找NAS未占用端口!Docker端口秒级排查+可视化占坑双杀技
- 【知识杂谈#2】如何查看Linux的(本地与公网)IP地址与SSH端口号
- 如何在Linux中查询 DNS 记录,这三个命令可谓是最常用、最经典的
- 【Linux系统编程】特殊进程之守护进程
- 标签列表
-
- 下划线是什么 (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)
本文暂时没有评论,来添加一个吧(●'◡'●)