SQL入门之多表查询

2018-06-17 23:34:53来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

如果查询需要针对两个或者更多个表,则在需要涉及到表的连接操作(join)。

0.笛卡儿积

最简单的连接方式是直接在from子句中加入两个表,并且用join操作符隔开。形式为Table1 join Table2。下面是例子:

select e.fname, e.lname, d.name
from employee e join department d;

产生108行数据,这是因为,对于单纯使用join进行的是笛卡儿积运算。对于两个表,分别由m和n个元组,进行笛卡尔积后将产生mXn个元组。但这个不是我们需要的结果,包含由很多不需要的数据。若要得到正确的结果,则需要内连接。

1.内连接

内连接根据相同属性值进行连接。只需要在上面的表中加上on和所需要相等的属性即可。

select e.fname, e.lname, d.name
from employee e join department d
on e.dept_id = d.dept_id;

结果正是想要的。其实,在join前可加inner这是默认情况。但对于良好习惯,应该加上,以指明这是什么连接,这有助于代码阅读。对于on e.dept_id = d.dept_id可以用using(dept_id)来代替。

以上结果也可以用SQL92的标准进行操作

 

select e.fname, e.lname, d.name
from employee e, department d
where e.dept_id = d.dept_id;

 

对于两种标准,选择在于自己,各有优缺点。

2.自连接

不仅在同一查询中多次包含同一个表,还可以对表自身进行连接。只需要取不同别名即可。

总结:对于连接操作方法挺好懂的,比较简单,对于连接3个以上,连接子查询,不等连接等类似。

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:SQL入门之条件表达式

下一篇:MySQL设置远程连接