题目
left join 与 right join 区别
如果紧紧只是说以前的表为主表就用left join ,后面的表为主表就用right join的话.那怎么就不把前后两个表的位置换一下?这样不是只要一个左或者右链接就行了?
如果紧紧只是说以前的表为主表就用left join ,后面的表为主表就用right join的话.那怎么就不把前后两个表的位置换一下?这样不是只要一个左或者右链接就行了?
提问时间:2020-05-19
答案
A left join B 的连接的记录数与A表的记录数同
A right join B 的连接的记录数与B表的记录数同
A left join B 等价B right join A
table A:
Field_K,Field_A
1 a
3 b
4 c
table B:
Field_K,Field_B
1 x
2 y
4 z
select a.Field_K,a.Field_A,b.Field_K,b.Field_B
from a left join b on a.Field_K=b.Field_K
Field_K Field_A Field_K Field_B
---------- ---------- ---------- ----------
1 a 1 x
3 b NULL NULL
4 c 4 z
select a.Field_K,a.Field_A,b.Field_K,b.Field_B
from a right join b on a.Field_K=b.Field_K
Field_K Field_A Field_K Field_B
---------- ---------- ---------- ----------
1 a 1 x
NULL NULL 2 y
4 c 4 z --
举个例子:
假设a表和b表的数据是这样的.
a b
id name id stock
1 a 1 15
2 b 2 50
3 c
select * from a inner join b on a.id=b.id
这个语法是连接查询中的内连接,它产生的结果是
两个表相匹配的记录出现在结果列表中.
根据上面的表,出现的结果是这样的
a.id name b.id stock
1 a 1 15
2 b 2 50
----------------------------
select * from a,b where a.id=b.id
这个语法是内连接的另外一种写法,其执行结果与inner join 一样
--------------------------------
select * from a left/right join b on a.id=b.id
这个是外连接语法中的左外连接或右外连接
如果是左外连接的话,它将显示a表的所有记录,
select a.*,b.* from a left join b on a.id=b.id
查询的结果是这样的:
a.id name b.id stock
1 a 1 15
2 b 2 50
3 c null null
--------------------------------------------
如果是右外连接的话,它将显示b表的所有记录,
select a.*,b.* from a right join b on a.id=b.id
查询的结果是这样的:
a.id name b.id stock
1 a 1 15
2 b 2 50
--
select a.*,b.* from a left join b on a.k = b.k
select a.*,b.* from a left outer join b on a.k =b.k
----------上面两种一样left join是left outer join的简写
select a.*,b.* from a left inner join b on a.k = b.k
没有这种写法,错误的语句.
A right join B 的连接的记录数与B表的记录数同
A left join B 等价B right join A
table A:
Field_K,Field_A
1 a
3 b
4 c
table B:
Field_K,Field_B
1 x
2 y
4 z
select a.Field_K,a.Field_A,b.Field_K,b.Field_B
from a left join b on a.Field_K=b.Field_K
Field_K Field_A Field_K Field_B
---------- ---------- ---------- ----------
1 a 1 x
3 b NULL NULL
4 c 4 z
select a.Field_K,a.Field_A,b.Field_K,b.Field_B
from a right join b on a.Field_K=b.Field_K
Field_K Field_A Field_K Field_B
---------- ---------- ---------- ----------
1 a 1 x
NULL NULL 2 y
4 c 4 z --
举个例子:
假设a表和b表的数据是这样的.
a b
id name id stock
1 a 1 15
2 b 2 50
3 c
select * from a inner join b on a.id=b.id
这个语法是连接查询中的内连接,它产生的结果是
两个表相匹配的记录出现在结果列表中.
根据上面的表,出现的结果是这样的
a.id name b.id stock
1 a 1 15
2 b 2 50
----------------------------
select * from a,b where a.id=b.id
这个语法是内连接的另外一种写法,其执行结果与inner join 一样
--------------------------------
select * from a left/right join b on a.id=b.id
这个是外连接语法中的左外连接或右外连接
如果是左外连接的话,它将显示a表的所有记录,
select a.*,b.* from a left join b on a.id=b.id
查询的结果是这样的:
a.id name b.id stock
1 a 1 15
2 b 2 50
3 c null null
--------------------------------------------
如果是右外连接的话,它将显示b表的所有记录,
select a.*,b.* from a right join b on a.id=b.id
查询的结果是这样的:
a.id name b.id stock
1 a 1 15
2 b 2 50
--
select a.*,b.* from a left join b on a.k = b.k
select a.*,b.* from a left outer join b on a.k =b.k
----------上面两种一样left join是left outer join的简写
select a.*,b.* from a left inner join b on a.k = b.k
没有这种写法,错误的语句.
举一反三
已知函数f(x)=x,g(x)=alnx,a∈R.若曲线y=f(x)与曲线y=g(x)相交,且在交点处有相同的切线,求a的值和该切线方程.
我想写一篇关于奥巴马的演讲的文章,写哪一篇好呢?为什么好
奥巴马演讲不用看稿子.为什么中国领导演讲要看?
想找英语初三上学期的首字母填空练习……
英语翻译
最新试题
- 11/2X2/3X3/4.X99/100X100/101递等式计算
- 2x/(1+x^5)的不定积分!
- 3设函数f(x)是实数集R上的增函数,令F(x)=f(x)-f(2-x). (Ⅰ)判断并证明F(x)在R上的单调性; (Ⅱ)若F(a)+F(b)>0,求证:a+b>2.
- 4It takes me (one hour) to get to school.跟据括号部分,提问
- 5纽约的经纬度是多少?
- 6一生只做一件事
- 7假使有一只鸟,它在有充足的能量下,且能一直飞行,它能逃脱地球的引力飞到外天空吗
- 8已知直线L经过P(1,1)倾斜角a=30度,求直线L的参数方程.
- 9问道问题,连词成句.you,can,me,tell,way,the,science,Museum,the,to.
- 10x的方程1+x/2-x=2m/x2-4的解也是不等式组{2/1-x>x-2{2(x-3)不小于x-8M取值
热门考点
- 1已知二次函数y=1/2x²+bx+c的图像经过点A(c,-2),且这个二次函数图像的对称轴是x=3,则二次函数的解析式为——————————
- 2《丑小鸭》到底要告诉我们什么
- 3great a she player is Swiss tennis 连词成句
- 4正负数的加减运算法则是什么?
- 5she has got (three) brothers.
- 6亲什么合作填一个词.
- 7she is fine.-----------is-----------?
- 8We thought it our duty to take care of the orphans.
- 9关于小学六年级《只有一个地球》的问题?
- 1042.5×0.99+0.425如何 简算