SQL入门之多表查询
2024-08-30 18:10:21
如果查询需要针对两个或者更多个表,则在需要涉及到表的连接操作(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个以上,连接子查询,不等连接等类似。
最新文章
- Entity Framework 6 Recipes 2nd Edition(9-4)译->;Web API 的客户端实现修改跟踪
- jdk顺序表笔记
- 基于Spring AOP的JDK动态代理和CGLIB代理
- clang: error: linker command failed with exit code 1 (use -v to see invocation)
- 大四实习准备6_android服务
- Android Fragment 基本介绍[转]
- File的文件提取的小练习
- Lucene初步搜索
- liunx下search文件内容的几种方式
- [Oracle Support]PeopleSoft Support中Fixes,Patches,Bundles,Packs?
- C++运算符重载(10)
- 有关数据传输GET和POST的方法的区别
- 认识 Less
- Oracle学习笔记三
- for循环将字典添加到列表中出现覆盖前面数据的问题
- 强化学习策略梯度方法之: REINFORCE 算法(从原理到代码实现)
- android websocket
- tar命令的实用详解(C参数和排除文件 --exclude)
- eclipse开发mapreduce程序时出现的问题
- Explaining Delegates in C# - Part 7 (Asynchronous Callback - Way 4)