Oracle数据库的高级查询(多表查询)

前面写了一些高级查询中的基础部分。在这里写写多表查询的一些方法。这里的SQL语句的字段讲得不太细,因为时间问题,大家只要看思维意思即可。

多表查询,就是要2个表以上有连接,使用关联字段,外键。多表连接后,就成了“笛卡称集”。比如部门表是2列字段2行值。而员工表是4列字段3行值的话,他们中间有一个外键关联,关联后的表就是6列字段6行值的一个关联后的表。这个表就是所谓的“笛卡称集”。想了解“笛卡称集”的可以百度查查看。

但这个“笛卡称集”表是一个无效表,只是一个两表的组合。两表关联,列数相加,行数相乘,得到了6列6行,我们需要用Where条件语句去把两表关联的字段值提取出来,这才是我们所要的关联表。

等值连接

示例:查询员工的信息,要求显示:员工号,姓名,月薪,部门名称(所谓等值连接,就是条件中用=号来判断的连接)从表中可以看出,这两表关联字段为DEPTNO
SELECT E.EMPNO,E.ENAME,E.SAL,D.DNAME FROM EMP E, DEPT D WHERE E.DEPTNO = D.DEPTNO

不等值连接

这里查询的是工资的范围。S表中有两个字段,这是取的是大于S.LO下限,小于S.HI上限
SELECT E.EMPNO,E.ENAME,E.ENAME,E.SAL,S.GRADE FROM EMP E, SALGRADE S WHERE E.SAL BETWEEN S.LO AND S.HI

外连接

外连接就是把对于连接条件不成立的记录,也包含在最后的结果当中,如果我们用的只是等值连接的话,而要查询的是各部门的人数,如果有一个部门没有人,在等值 连接那边,就不会显示出来,但我们要的是显示所有部门的人数,就算部门没人也要显示。这就要用到外连接了。可以以哪一个为主表,主表中的所有字段值都会显示 出来,而子表中字段值只会在与主表相同的情况下的字段值才会显示,不同的,将会去除。这讲的有点抽象,那把外连接分为两部分,这就要看你要以哪个表为主了。
左外连接:当连接条件不成立的时候,等号左边的表仍然被包含;
WHERE E.DEPTNO = D.DEPTNO(+)
右外连接,当连接条件不成立的时候,等号右边的表仍然被包含;
WHERE E.DEPTNO(+) = D.DEPTNO

自连接

自连接是针对一张表当成两表连接,通过别名,将同一张表视为两张表,以下语法是在同一张表中查询员工所对应的上级领导的名字,
另外要注意的是,自连接不适合操作大表,也就是字段值很多的表。我们前面有谈到“笛卡称集”,只要是多表连接,就会产生“笛卡称集” 。也就是说,自连接如果只是 当成两表连接的话,如果有3个字段值,那他产生的“笛卡称集”数就是3的平方,也就是9个COUNT(*)、如果你表很大。这样产生的“笛卡称集”就太庞大了。但也可以使 用“层次查询”解决上面的问题
SELECT E.ENAME 员工姓名,B.ENAME 老板姓名 FROM EMP E, EMP B WHERE E.MGR = B.EMPNO


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值