首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

大数据 面试 SQL left join 测试结果

这个题目的正确答案为B,下面是大家选择结果,准确率为36%,说明大家还是忽略了一些基础知识的细节的。 我们可以看到,选择集中在B和C,差别点在结果是否包含“1,null”该行。...第一点:大家都能够确定的是t2.id肯定是NULL,说明大家对于on条件中的t1.id = 2 的关联条件,可以限制t2表的结果; 第二点:left join 中的on条件是关联条件,不限定左表数据,所以...t1表中的所有数据都需要保留; 第三点:在真实需求下,期望得出C的结果是错写出该SQL,产出C结果SQL如下: select t1.id, t2.id from t1 left join t2 on...,这样既可以减少关联计算涉及的数据量,也减少逻辑的复杂度,可读性更好.如果业务逻辑复杂上面的SQL出错的可能性还是比较高的,所以我通常的写法如下: select new_t1.id, new_t2....id from ( select id from t1 where t1.id=2 ) new_t1 left join ( select id from t2 )new_t2 on

14510
您找到你想要的搜索结果了吗?
是的
没有找到

sql连接查询(inner join、full join、left join、 right join

sql连接查询(inner join、full join、left join、 right join) 一、内连接(inner join) 首先我这有两张表 1、顾客信息表customer ?..., o.create_time, o.money from customer c inner join orders o on c.id = o.customer_id 结果: ?...o.customer_id 结果: ?...从结果可以很清楚的明白左连接的含义: 将左边表的所有记录拿出来,不管右边表有没有对应的记录 三、右连接(right join) 需求:查询哪个顾客(customer_name)在哪一天(create_time...、 从结果可以很清楚的明白右连接的含义: 将右边表的所有记录拿出来,不管右边表有没有对应的记录 四、全连接(full join) 这里要注意的是mysql本身并不支持全连接查询,但是我们可以使用UNION

4.1K40

SQL基础【十五、join、Inner join、Left join、Right join、Full join

Join 数据库中的表可以通过键将彼此联系起来,主键是一个列,在这个列中的每一行的值都是唯一的,在表中,每个主键的值都是唯一的,这样就可以在不重复每个表中的所有数据的情况下,把表间的数据交叉捆绑在一起。...and r.room_name='room of boy' Inner join Inner joinjoin 用法一致 Select u.user_name,u.user_age,r.room_name...from user as u inner join room as r on u.room_id = r.room_id and r.room_name='room of boy' Left join...user Full join room 2:Room在左边 Select * From room full join user 注意:SQL错误码1054表示没有找到对应的字段名;错误码1064表示用户输入的...SQL语句有语法错误 希望能对大家有所帮助。

1.5K20

sql之left join、right join、inner join的区别

sql语句如下: select * from A left join B on A.aID = B.bID 结果如下: aID     aNum     bID     bName 1     a20050111...B表记录不足的地方均为NULL. -------------------------------------------- 2.right join sql语句如下: select * from A...right join B on A.aID = B.bID 结果如下: aID     aNum     bID     bName 1     a20050111    1     2006032401...: 仔细观察一下,就会发现,和left join结果刚好相反,这次是以右表(B)为基础的,A表不足的地方用NULL填充. ---------------------------------------...----- 3.inner join sql语句如下: select * from A innerjoin B on A.aID = B.bID 结果如下: aID     aNum     bID

1.8K30

sql之left join、right join、inner join的区别

sql语句如下: select * from A left join B on A.aID = B.bID 结果如下: aID     aNum     bID     bName 1     a20050111...B表记录不足的地方均为NULL. -------------------------------------------- 2.right join sql语句如下: select * from A...right join B on A.aID = B.bID 结果如下: aID     aNum     bID     bName 1     a20050111    1     2006032401...: 仔细观察一下,就会发现,和left join结果刚好相反,这次是以右表(B)为基础的,A表不足的地方用NULL填充. ---------------------------------------...----- 3.inner join sql语句如下: select * from A innerjoin B on A.aID = B.bID 结果如下: aID     aNum     bID

1.5K80

SQL中关于Join、Inner Join、Left Join、Right Join、Full Join、On、 Where区别

前言:   今天主要的内容是要讲解SQL中关于Join、Inner Join、Left Join、Right Join、Full Join、On、 Where区别和用法,不用我说其实前面的这些基本SQL...数据库(MS Sql Server)表结构和对应数据: Students 学生表: ? Class 班级表: ?...Inner Join(内连接查询): 概念:与Join相同,两表或多表之间联立查询数据,因此我们在使用多表join查询的时候既可以使用where关联,也可以是inner join关联查询 select...Left Join(左连接查询): 概念:以左表中的数据为主,即使与右表中的数据不匹配也会把左表中的所有数据返回 select * from Students s left join Class c...ON的使用无论是左右内全都使用到了On来进行关联: 对于Inner Join 的作用就是起到了与where相同的作用条件筛选: select * from Students s inner JOIN

2.4K20

sql之left join、right join、inner join的区别

left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录 right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录 inner join(等值连接) 只返回两个表中联结字段相等的行...left join是以A表的记录为基础的,A可以看成左表,B可以看成右表,left join是以左表为准的....B表记录不足的地方均为NULL. -------------------------------------------- 2.right join 仔细观察一下,就会发现,和left join结果刚好相反...JOIN操作用于在任何的 FROM 子句中,组合来源表的记录。...如果在INNER JOIN操作中要联接包含Memo 数据类型或OLE Object 数据类型数据的字段,将会发生错误.

1.2K20
领券