SQL JOIN 子句用于把来自两个或多个表的行结合起来,基于这些表之间的共同字段。
LEFT JOIN(左连接) 返回包括左表中的所有记录和右表中联结字段相等的记录。
即使右表中没有匹配,也从左表返回所有的行。
RIGHT JOIN(右连接)返回包括右表中的所有记录和左表中联结字段相等的记录。
即使左表中没有匹配,也从右表返回所有的行。
示例表:表1和表2
1、LEFT JOIN 例:
注释:王五在表2中没有匹配的记录,所以表2的内容为NULL。
2、RIGHT JOIN例:
注释:表2中所有记录被返回。
扩展资料:
sql语句中left join的效率问题
sql语句中包含数据处理函数(nvl,case when函数);inner joinleft join等关联;排序和分页。
1、首先把排序去掉,速度确实很快,但排序是必须的,这样做只是为了证明排序是很耗资源。2、将nvl,case when等函数去掉,结果速度几乎没有任何改变。
3、将inner join的表去除,速度稍微快了几十毫秒。
4、将left join的表去掉,速度从原来的4秒提高到1秒内。
综合所得,left join才是速度慢的元凶,于是将left join关联关系字段都加为索引,发现速度基本能保持在1秒左右。
结论:left join是相当耗资源的 *** 作,如果关联的字段没有索引的话,速度是很慢的,所以如果有left join的话,最好用索引字段取关联,或者给关联的字段加索引。
参考资料:
百度百科Left join
百度百科Right join
数据库 内连接 外连接 区别
(一)内连接
内连接查询 *** 作列出与连接条件匹配的数据行,它使用比较运算符比较被连接列的
列值。内连接分三种:
1、等值连接:在连接条件中使用等于号(=)运算符比较被连接列的列值,其查询结
果中列出被连接表中的所有列,包括其中的重复列。
例,下面使用等值连接列出authors和publishers表中位于同一城市的作者和出版社:
SELECT
FROM authors AS a INNER JOIN publishers AS p
ON acity=pcity
2、不等连接: 在连接条件使用除等于运算符以外的其它比较运算符比较被连接的
列的列值。这些运算符包括>、>=、<=、<、!>、!<和<>。
3、自然连接:在连接条件中使用等于(=)运算符比较被连接列的列值,但它使用选
择列表指出查询结果集合中所包括的列,并删除连接表中的重复列。
例,在选择列表中删除authors 和publishers 表中重复列(city和state):
SELECT a,ppub_id,ppub_name,pcountry
FROM authors AS a INNER JOIN publishers AS p
ON acity=pcity
(二) 外连接
外连接,返回到查询结果集合中的不仅包含符合连接条件的行,而且还包括左表(左
外连接或左连接))、右表(右外连接或右连接)或两个边接表(全外连接)中的所有数据行。
left join(左联接) 返回包括左表中的所有记录和右表中联结字段相等的记录;
right join(右联接) 返回包括右表中的所有记录和左表中联结字段相等的记录;
例如1:SELECT a,b FROM luntan LEFT JOIN usertable as b
ON ausername=busername
例如2:SELECT a,b
FROM city as a FULL OUTER JOIN user as b
ON ausername=busername
(三) 交叉连接
交叉连接不带WHERE 子句,它返回被连接的两个表所有数据行的笛卡尔积,返回到
结果集合中的数据行数等于第一个表中符合查询条件的数据行数乘以第二个表中符合查
询条件的数据行数。例,titles表中有6类图书,而publishers表中有8家出版社,则下
列交叉连接检索到的记录数将等于68=48行。
例如:SELECT type,pub_name
FROM titles CROSS JOIN publishers
ORDER BY type
就是域相同的属性值相等就连接。
比如:比如有R(A,B)和S(B,C)两个关系,自然连接的条件就是RB=SB,结果是一个关系,为3个属性(A,B,C)。
通过相同名字的属性连接的结果就是自然连接。自然连接是在笛卡尔积中选取属性值(对于这个例子就是属性B)相等的那些条目,然后把重复的属性删掉。
本例的自然连接就是 {m 1 3},并和交需要两个关系的结构相同,本例R的结构是属性A B S的结构是属性B C, 故而不能做交或者并的运算。
自然连接又叫笛卡尔乘积,是一个叫笛卡尔的人提出来的。简单的说就是两个集合相乘的结果。具体的定义去看看有关代数系的书的定义。直观的说就是集合A{a1,a2,a3} 集合B{b1,b2} ,他们的 笛卡尔积是 AB ={(a1,b1),(a1,b2),(a2,b1),(a2,b2),(a3,b1),(a3,b2)}。任意两个元素结合在一起三、并 两个逻辑算式之间的比较 如果不全为真,则结果为假 例如有逻辑算式A 、B A B 结果 值真真真、 值真假假 、值假真假 、值假假假 。
连接分内连接,外连接,交叉连接,等值连接和自连接。内连接是在公共的列上使用比较 *** 作符从多表中抽取数据。(某一公共属性如EmployeeID,它是A表的主键和B表的外键)1左连接返回left outer join 关键字左侧指定的表的所以行和右侧指定的表的匹配的行。2右连接返回right outer join 关键字右侧指定的表的所以行和左侧指定的表的匹配的行。3完全外连接返回来自两个表的所以匹配和非匹配行使用full outer join 关键字。交叉连接就是笛卡尔积,A表有5行,B表有10行,使用交叉连接就有50行。等值连接是内连接的一种特殊形式,它是要选择所有表的所以属性列。自连接就是一个表和自己连接。为区分同一个表的两个实例,表被给出两个别名。
假设在成绩表有主键ID学生姓名课程名称成绩等字段。
现在要查询 “语文成绩>=数学成绩”的学生姓名,这时就可以使用自连接查询:
select 学生姓名
from 成绩表 AS a,成绩表 AS b
where a主键ID=b主键ID
and a成绩>=b成绩
and a课程名称='语文'
and b课程名称='数学'
自连接是指使用表的别名实现表与其自身连接的查询方法。
1
指通过对参与表关系中所有同名的属性对取等(即相等比较)来完成的,故无须自己添加连接条件,例:select
from
student
natual
join
teacher。
2
同属于join *** 作,还包括外连接和内连接。
以上就是关于数据库 *** 作中,左连接,右连接是什么意思,举例说明全部的内容,包括:数据库 *** 作中,左连接,右连接是什么意思,举例说明、数据库中自然连接与内连接的区别、谁知道数据库中的自然连接是怎么算的我学C语言,那是公共基础知识。我看不懂.........最好具体点等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)