SQL语句复习【专题四】

多表查询 sql 92
多表查询 sql92、sql99 标准
--查询所有员工的姓名,部门编号,部门名称
select * from emp
select * from dept
--笛卡尔集
select * from emp, dept
--消除笛卡尔集中的冗余的数据
select *
from emp, dept
where emp.deptno=dept.deptno--表的连接查询条件

等值连接查询
--查询所有员工的姓名,部门编号,部门名称
注意:如果多个表间存在相同的字段的名称,那么必须指明显示的字段属于哪一张表。
select ename, emp.deptno,dname
from emp, dept
where emp.deptno=dept.deptno

给表起别名:注意:给表起别名不能使用 as 。一旦给表起了别名,那么原本的表的名称就不能再使用。
select ename, e.deptno,dname
from emp e, dept d
where e.deptno=d.deptno

select ename, e.deptno,dname
from emp e, dept d
where e.deptno <> 10 and e.deptno=d.deptno

sql 92中,表的连接条件: 在where 中书写 表连接的条件。where 中既可以写行过滤,也要写 表连接。
--非等值连接
--查询所有员工的姓名,职位,薪水,薪水等级 emp 和 salgrade 两个表的多表查询
select *
from emp e, salgrade s
--非等值连接
select e.ename, e.job, e.sal ,s.grade
from emp e, salgrade s
where e.sal >=s.losal and e.sal <= s.hisal
--尽量将所有的显式的字段,都使用表名引用 ,可以提高访问的效率。

自连接
--查询 员工的编号,名字,员工的上级的编号,上级的名字
select * from emp
将一张表 看作两张表。
--一张员工表 emp。想象成一张作为领导的上级的表。
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1, emp e2
where e1.mgr=e2.empno

外连接 【左右外连接】
左外连接
--查看不满足条件的记录
--查询 员工的编号,名字,员工的上级的编号,上级的名字,包含没有上级的员工
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1, emp e2
where e1.mgr=e2.empno(+)--左外连接,就是将左表的不满足条件的内容也显示出来。

右外连接
--查询 员工的编号,名字,员工的上级的编号,上级的名字,包含没有下级的员工的信息
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1, emp e2
where e1.mgr(+)=e2.empno--右外连接,就是将右表的不满足条件的内容也显示出来。

--查询部门的所有信息,以及每个部门的平均工资,包含没有员工的部门
select d.*,avg(sal)
from emp e, dept d
where e.deptno(+)=d.deptno--右外连接
group by d.deptno,d.dname,d.loc

三表连接
--查询20号部门的员工的编号,姓名,薪水,部门名称,薪水等级。
select d.deptno, e.empno,e.ename,e.sal,d.dname,s.grade
from emp e, dept d, salgrade s
where d.deptno=20 and e.deptno=d.deptno and e.sal >=s.losal and e.sal<= s.hisal

n张表,至少需要几个连接条件? 需要n-1 个连接条件

sql 92:连接条件和 行过滤条件都在where子句中 书写。
sql 99:表的连接条件 和 行过滤条件分开了。where 只做行过滤。表的连接条件在其他的地方进行。
--交叉连接 cross join 和笛卡尔集是一样的
--sql92
select *
from emp e, dept d
--sql 99
select *
from emp e cross join dept d

--查询所有员工的姓名,部门编号,部门名称
--sql92
select e.ename,e.deptno,d.dname
from emp e, dept d
where e.deptno=d.deptno

自然连接 natural join 等值连接:
连接条件被隐式指定,自动使用两个进行自然连接的表中的相同的字段进行等值连接。作为连接条件的列,不能指定该列的表的限定。语法的要求。
优点:不需要指明连接条件,条件是隐式指定的。
缺点:不能指定连接条件,如果多个表中有多个相同的字段,那么会自动使用多个字段进行等值连接,不够灵活。只能做等值连接。
select e.ename,deptno,d.dname
from emp e
natural join dept d

Using 子句:只能做等值连接。需要连接的表中存在相同的字段,可以显式指定多表之间的等值连接条件,可以指定多个字段进行等值连接。
--sql 99
select e.ename,deptno,d.dname
from emp e
inner join dept d--内连接 inner 可以省略
Using(deptno)

select e.ename,deptno,d.dname
from emp e
join dept d--内连接 inner 可以省略
Using(deptno)

on 子句连接:既可以等值连接也可以不等值连接
--查询30部分的员工的编号,姓名,部门名称
--sql 92
select d.deptno, e.empno,e.ename,d.dname
from emp e, dept d
where d.deptno=30 and e.deptno=d.deptno
--sql 99
select d.deptno, e.empno,e.ename,d.dname
from emp e join dept d
on e.deptno=d.deptno---等值连接
where d.deptno=30

--查询10部门员工的姓名,薪水等级---不等值连接
--sql 92
select e.deptno,e.ename, s.grade
from emp e, salgrade s
where e.deptno=10 and e.sal >= s.losal and e.sal <= s.hisal
--sql 99
select e.deptno,e.ename, s.grade
from emp e join salgrade s
on e.sal >= s.losal and e.sal<=s.hisal
where e.deptno=10

自连接
--查询 员工的编号,名字,员工的上级的编号,上级的名字
--sql 92
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1, emp e2
where e1.mgr=e2.empno
--sql99
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1 join emp e2
on e1.mgr=e2.empno

外连接
1)左外连接 left [outer] join 左边的表的不满连接条件的信息全部显式
2)右外连接 right [outer] join 右边的表的不满连接条件的信息全部显式
3)全外连接 full [outer] join 左边和右边的表的不满连接条件的信息全部显式
--sql 99 左外 包含没有上级的员工的信息
--sql 92
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1,emp e2
where e1.mgr=e2.empno(+)
--sql99
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1 left outer join emp e2
on e1.mgr=e2.empno

--sql 99 右外 包含没有下级的员工的信息
--sql 92
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1, emp e2
where e1.mgr(+)=e2.empno
--sql 99
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1 right join emp e2
on e1.mgr=e2.empno

--sql 99 全外 包含没有上下级的员工的信息
--sql99
select e1.empno,e1.ename,e1.mgr,e2.ename
from emp e1 full join emp e2
on e1.mgr=e2.empno

--sql 99 查询部门的所有信息,以及每个部门的平均工资,包含没有员工的部门
--sql 92
select d.*,avg(sal)
from emp e, dept d
where e.deptno(+)=d.deptno
group by d.deptno,d.dname,d.loc
--sql99
select d.*,avg(sal)
from emp e right outer join dept d
on e.deptno=d.deptno
group by d.deptno,d.dname,d.loc

--查询20号部门的员工的编号、姓名、薪水、部门名称,薪水等级
--三表
--sql 92
select d.deptno ,e.empno,e.ename,e.sal,d.dname,s.grade
from emp e, dept d, salgrade s
where d.deptno=20 and e.deptno=d.deptno and e.sal >= s.losal and e.sal<=s.hisal

--sql 99 natural join 隐式连接的字段不能添加表的限定
select deptno,e.empno,e.ename,e.sal,d.dname,s.grade
from emp e natural join dept d join salgrade s
on e.sal>=s.losal and e.sal<=s.hisal
where deptno=20

--sql 99 Using + on Using 等值连接的字段,不要指定表的限定
select deptno,e.empno,e.ename,e.sal,d.dname,s.grade
from emp e join dept d
Using(deptno)
join salgrade s
on e.sal>=s.losal and e.sal<=s.hisal
where deptno=20

--sql 99 on on 中的等值连接部分,如果显式等值连接的字段,需要对字段指定属于哪一个表。
select d.deptno,e.empno,e.ename,e.sal,d.dname,s.grade
from emp e join dept d
on e.deptno=d.deptno
join salgrade s
on e.sal>=s.losal and e.sal<=s.hisal
where d.deptno=20

SQL语句复习【专题四】的更多相关文章

  1. SQL语句复习【专题六】

    SQL语句复习[专题六] 用户 + 创建表  --创建一个新的用户,然后给新的用户创建一张表,然后给表中添加一些数据.查询表中的数据 --创建用户需要比较大的权限 DBA create user di ...

  2. SQL语句复习【专题一】

    SQL语句复习[专题一] --创建用户 scott 并设置密码为 tiger create user scott identified by tiger --用户刚刚创建没有任何的权限,连登录的权限都 ...

  3. SQL语句复习【专题二】

    SQL语句复习[专题二] 单行函数(日期.数学.字符串.通用函数.转换函数)多行函数.分组函数.多行数据计算一个结果.一共5个.sum(),avg(),max(),min(),count()分组函数  ...

  4. SQL语句复习【专题三】

    SQL语句复习[专题三] DML 数据操作语言[insert into update delete]创建表 简单的方式[使用查询的结果集来创建一张表]create table temp as sele ...

  5. SQL语句复习【专题五】

    SQL语句复习[专题五] 单行子查询:只会得到一个结果的子查询[子查询的内容必须放在小括号中.在查询语句中的查询语句 ]--查询所有比 CLARK 员工 工资高的员工--1.先查询 CLARK 员工的 ...

  6. SQL语句复习【专题七】

    SQL语句复习[专题七] 完整性约束分类1)域完整性约束(非空not null,检查check)2)实体完整性约束(唯一unique,主键primary key)3)参照完整性约束(外键foreign ...

  7. SQL语句复习【专题八】

    SQL语句复习[专题八] 序列 Sequence.数据库对象是 oracle 专有的.作用:可以将某一列的值使用序列,来实现自动增长的功能.访问序列的值.[序列有两个属性 nextval currva ...

  8. SQL语句复习【专题九】

    SQL语句复习[专题九] 视图:View视图的概念:视图是从若干基本表或其他视图构造出来的表.在创建一个视图时,只是存放的视图的定义,也即是动态检索数据的查询语句,而并不存放视图对应的数据在用户使用视 ...

  9. sql语句复习(基础-提升-技巧-经典数据开发案例-sql server配置)

    1 基础 1.说明:创建数据库 CREATE DATABASE database-name charset=utf8 2.说明:删除数据库 drop database dbname 3.说明:备份sq ...

随机推荐

  1. 【经验】Delphi INI文件保存与读取

    //需要引用IniFiles uses system.IniFiles; //保存INI配置文件 procedure TForm1.btnSaveClick(Sender: TObject); var ...

  2. SQL中group by后面的having中不能使用别名

    如下图中,SQL中需要对group by的结果使用having进行过滤,不能使用select中定义的别名,需要使用查询字段的原始名.否则会报错,列明未定义. 下图未错误演示: 修改后,正确的SQL语句 ...

  3. 打开svn时出现 R6034

    An application has made an attempt to load the C runtime library...... 最后发现是因为环境变量path里面有:E:\anacond ...

  4. 【POJ - 1703】Find them, Catch them(种类并查集)

    Find them, Catch them 直接翻译了 Descriptions 警方决定捣毁两大犯罪团伙:龙帮和蛇帮,显然一个帮派至少有一人.该城有N个罪犯,编号从1至N(N<=100000. ...

  5. 《精通并发与Netty》学习笔记(02 - 服务端程序编写)

    上节我们介绍了开发netty项目所必需的开发环境及工具的使用,这节我们来写第一个netty项目 开发步骤 第一步:打开https://search.maven.org 找到netty依赖库 第二步:打 ...

  6. 看kubelet的日志 + Kubeadm安装Kubernetes环境

    1.通过journalctl看日志 journalctl -xeu kubelet > a参考:https://www.cnblogs.com/ericnie/p/7749588.html

  7. iptables 命令

    NAME iptables — administration tool for IPv4 packet filtering and NAT SYNOPSIS iptables -ADC 指定链的规则 ...

  8. 计蒜客习题:蒜头君的积木 (状压DP 枚举子集)

    问题描述 蒜头君酷爱搭积木,他用积木搭了 n 辆重量为 wi的小车和一艘最大载重量为 W 的小船,他想用这艘小船将 n 辆小车运输过河.每次小船运载的小车重量不能超过 W.另外,小船在运载小车时,每辆 ...

  9. Capacity To Ship Packages Within D Days

    A conveyor belt has packages that must be shipped from one port to another within D days. The i-th p ...

  10. Web 开发和数据科学家仍是 Python 开发的两大主力

    由于 Python 2 即将退役,使用 Python 3 的开发者大约为 90%,Python 2 的使用量正在迅速减少.而去年仍有 1/4 的人使用 Python 2. Web 开发和数据科学家仍是 ...