利用EF Core的Join进行多表查询

简介: 背景 话说有这么一家子,老公养了一条狗,老婆养了一只猫。 数据库的设计 人表   宠物表     通过表可以知道,宠物通过Owner指向主人的Id。   问题来了,我要和故事开头一样,老公-狗,老婆-猫,对应起来,怎么查询呢? 有同学说这还不简单?两个遍历一下不就行了。

背景

话说有这么一家子,老公养了一条狗,老婆养了一只猫。

数据库的设计

人表

 

宠物表

 

 

通过表可以知道,宠物通过Owner指向主人的Id。

 

问题来了,我要和故事开头一样,老公-狗,老婆-猫,对应起来,怎么查询呢?

有同学说这还不简单?两个遍历一下不就行了。

首先 取出 List<宠物>集合,再根据宠物的主人Id去查找对应的主人信息就好了。

如果这样设计,那么将会执行3次查询:

l  查出所有的宠物。

l  查出阿猫的主人。

l  查出阿狗的主人。

数据量不大还好,数据量要是大一点这是非常影响速度的。这时,我们可以用到EF Core所有的Join方法进行多表查询。

 

我的做法是定义了一个PetsDetails的类,其代码如下:

  public class PetsDetails
    {
        /// <summary>
        /// 宠物名称
        /// </summary>
        public string PetName { get; set; }
        /// <summary>
        /// 主人名称
        /// </summary>
        public string OwnerName { get; set; }
    }

用EF 的Join方法进行多表查询:

        [HttpGet]
        public List<PetsDetails> Get()
        {
            return _context.Pets.Join(_context.Persons,pet=>pet.Owner,per=>per.Id,(pet,per)=>new PetsDetails
            {
                PetName = pet.Name,
                OwnerName = per.Name
            }).ToList();
        }

执行结果如图:

成功取到了宠物对应的主人的名称。

好处

原本需要进行3次查询的,用了Join方法后一次查询即可取到所需要的结果。我们看看这条Sql语句的样子:

我们看到其实这个需求是EF通过再sql语句中执行INNER JOIN实现的。

完整项目代码:

https://github.com/liuzhenyulive/EF-CORE-JOIN-Demo

您的支持是我最大的动力,如果满意,请帮我点击推荐。

 

相关文章
|
3月前
|
存储 关系型数据库 MySQL
mysql中的left join、right join 、inner join的详细用法
【8月更文挑战第16天】在MySQL中,`INNER JOIN`、`LEFT JOIN`与`RIGHT JOIN`用于连接多表。`INNER JOIN`仅返回两表中匹配的行;`LEFT JOIN`保证左表所有行出现于结果中,右表无匹配时以NULL填充;`RIGHT JOIN`则相反,保证右表所有行出现于结果中。例如,查询学生及其成绩时,`INNER JOIN`仅显示有成绩的学生;`LEFT JOIN`显示所有学生及他们对应的成绩,无成绩者成绩列为空;`RIGHT JOIN`显示所有成绩及对应学生信息,无学生信息的成绩条目则为空。
|
6月前
|
SQL Oracle 关系型数据库
Oracle查询优化-left join、right join、inner join、full join和逗号的区别
【1月更文挑战第5天】【1月更文挑战第13篇】实际查询时,多表联查是常规操作,但是连接方式有多种。
489 0
|
SQL
07SQL - letf join 和 inner join 的 区别
07SQL - letf join 和 inner join 的 区别
56 0
|
SQL
★SQL高级教程(2)——Alias、JOIN、INNER JOIN...(建议收藏)★下
★SQL高级教程(2)——Alias、JOIN、INNER JOIN...(建议收藏)★下
126 0
|
SQL 数据库
★SQL高级教程(2)——Alias、JOIN、INNER JOIN...(建议收藏)★上
★SQL高级教程(2)——Alias、JOIN、INNER JOIN...(建议收藏)★上
182 0
|
SQL 数据库
SQL中关于Join、Inner Join、Left Join、Right Join、Full Join、On、 Where区别
SQL中关于Join、Inner Join、Left Join、Right Join、Full Join、On、 Where区别
136 0
SQL中关于Join、Inner Join、Left Join、Right Join、Full Join、On、 Where区别
|
SQL 语音技术 数据库
SQL基础【十五、join、Inner join、Left join、Right join、Full join】
SQL基础【十五、join、Inner join、Left join、Right join、Full join】
160 0
SQL基础【十五、join、Inner join、Left join、Right join、Full join】
|
关系型数据库 MySQL
MySQL 超新手入门(5) JOIN 与 UNION 查询
在「world」资料库的「country」表格中,储存世界上所有的国家资料,其中有一个栏位「Capital」用来储存首都资料,不过它只是储存一个编号;另外在「city」表格中,储存世界上所有的城市资料,它主要的栏位有城市编号和城市的名称:
194 0
MySQL 超新手入门(5) JOIN 与 UNION 查询
mysql的inner join, left join, right join
mysql的inner join, left join, right join 0. 先看表数据: mysql> select * from a; id age 1 10 2 20 3 30 4 40 4 rows in set (0.
894 0