杨中科 .NETCORE EFCORE第七部分 一对一,多对多

一对一


一对一关系配置

1、builder.HasOne(o =>o.Delivery).WithOne(d=>d.Order).HasForeignKey(d=>dOrderId);

2、测试插入和获取数据

示例

新建 Order

新建 Delivery

DeliveryConfig

OrderConfig

执行 迁移命令

查看数据库


测试数据插入


运行查看数据

多对多

1、多对多:老师一学生

2、EF Core 5.0开始,才正式支持多对多

3、需要中间表,举例数据

多对多实体

class Student

public long Id { get; set; }

public string Name { get; set;}

public List Teachers { get; set;} = new List();

classTeacher

public long Id { get; set; )

public string Name { get; set;)

public ListStudents { get; set;} = new List();

多对多关系配置

builder.HasMany(s =>s.Teachers).WithMany(t=>t.Students).UsingEntity(j=>j.ToTable("T_Students_Teachers"));

示例:

新建Student

添加Teacher

配置StudentConfig

配置TeacherConfig

配置DbContext

执行数据库迁移命令


生成的数据库 表

Student

Teacher

指定的关系表

插入数据测试

运行结果:


查询一下所有的老师,并且列出他们的学生

运行结果

基于关系的复杂查询

关系数据查询

1、查询评论中含有"微软"的所有的文章:ctx.Articles.Where(a=>a.Comments.Any(c=>c.Mesage.Contains("微软")));

2、查看生成的SOL语句。

示例:

运行结果 和 sql

变换形式

1、变换成另一种写法

ctx.Comments.Where(c => c.Message.Contains("微")

.Select(c => c.Article).Distinct();

2、查看生成的SQL语句

3、同样效果的代码可能有多种写法,有时候要关注底层的SQL,看哪种方式最好

示例:

运行结果和sql

重复情况,

解决方式,加上Distinct()排重

运行结果:

例子

1、查询"所有由蜗牛快递负责的订单信息力

ctx.Orders.Where(o=>o.Delivery.CompanyName=="蜗牛快递")

示例:

相关推荐
月光水岸New2 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
狄加山6752 小时前
数据库基础1
数据库
我爱松子鱼2 小时前
mysql之规则优化器RBO
数据库·mysql
chengooooooo3 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
Rverdoser4 小时前
【SQL】多表查询案例
数据库·sql
Galeoto4 小时前
how to export a table in sqlite, and import into another
数据库·sqlite
人间打气筒(Ada)4 小时前
MySQL主从架构
服务器·数据库·mysql
leegong231114 小时前
学习PostgreSQL专家认证
数据库·学习·postgresql
喝醉酒的小白4 小时前
PostgreSQL:更新字段慢
数据库·postgresql
敲敲敲-敲代码4 小时前
【SQL实验】触发器
数据库·笔记·sql