Oracle 10g数据库基础之基本查询语句-下-连接&子查询

简介:

 Oracle 10g数据库基础之基本查询语句-下-连接&子查询

-- 资料参考:张烈  张建中《数据库管理员培训讲义》
实验18:表的连接查询
该实验的目的是掌握基本的联合查询 .
表的连接
我们要从多张表中要得到信息,就得以一定的条件将表连接在一起查询。

Cartesian (笛卡儿)连接

当多张表在一起查询时,没有给定正确的连接条件,结果是第一张表的所有行和第二张表的所有行进行矩阵相乘,得到n*m行的结果集。

一般来说笛卡儿连接不是我们需要的结果。
但表如果有一行的情况下,结果有可能正确。

SQL> select ename,dname from emp,dept;

 
ENAME      DNAME

---------- --------------

SMITH      ACCOUNTING
ALLEN      ACCOUNTING
……..
SMITH      RESEARCH
ALLEN      RESEARCH
……..
SMITH      SALES
ALLEN      SALES
……..
SMITH      OPERATIONS
ALLEN      OPERATIONS
……..
 
56 rows selected
 
SQL>

结果为每个员工在每个部门上了一次班,4*14=56,这并不是我们想得到的结果。

要避免笛卡儿连接一定要给定一个正确的连接条件。
等值连接
在连接中给定一个相等的连接条件。
SQL> select ename,dname from emp,dept where emp.deptno=dept.deptno;

当列的名称在两张表内重复的时候,要加表的前缀来区分,避免不明确的定义。
表的别名
1 。便于书写
2 。将同名的表区分
3 。一旦定义了别名,表的本名就无效
4 。只在该语句内有效
5 。定义方式为表名后紧跟别名,用空各间隔。

SQL> select ename,dname from emp e,dept d where e.deptno=d.deptno;

SQL99 的书写方式

select ename,dname from emp e join dept d on (e.deptno=d.deptno)

效率是相同的,SQL99是国标

列的别名,为了区分相同的列的名称,这是别名的本质。
SQL> select ename,dname,e.deptno,d.deptno

  from emp e,dept d

  where e.deptno=d.deptno;

上述显示有两个列名称都叫deptno,我们无法区分。

SQL> select ename,dname,e.deptno "员工表",d.deptno "部门表"

  from emp e,dept d
  where e.deptno=d.deptno;

不等连接
连接条件不是一个相等的条件。

SQL> select ename,sal,grade

  from emp,salgrade
  where sal between LOSAL and hisal;

外键连接
将一张表有,而另一张表没有的行也显示出来。

SQL> select ename,dname,emp.deptno from emp,dept

where emp.deptno=dept.deptno;

这句话不会显示40号部门,因为40部门没有员工。

SQL> select ename,dname,dept.deptno from emp,dept where emp.deptno(+)=dept.deptno;

+号的意思为将没有员工的部门,用NULL来匹配

+号不能同时放在等号的两边,只能出现在一边。

自连接
表的一列和同一个表的另一列作为连接的条件。

SQL> select w.ename "下级" ,m.ename "上级"

  from emp w,emp m
  where w.mgr=m.empno(+);

其中“下级”“上级”为列的别名。区分相同的列。

W为表的别名。区分相同的表。别名的本质。

+)为了将没有上级的人也显示。

过滤结果

想在结果中过滤去一些内容请用and运算。

SQL> select w.ename "下级" ,m.ename "上级"

  from emp w,emp m
  where w.mgr=m.empno(+)
  and w.deptno=30;

实验19:sql99规则的表连接操作

该实验的目的是掌握新的ORACLE表之间的联合查询语法.

SQL99 规则的书写格式

. Nature(自然)连接

这是SQL99规则。

所有同名的列都作为等值条件。
同名的列的数据类型必须匹配。
列的名称前不能加表的前缀。

SQL> select ename,deptno,dname from emp natural join dept;

Using 指定列的连接
当有多列同名,但想用其中某一列作为连接条件时使用。
SQL> select ename,deptno ,dname from emp join dept using (deptno);

SQL99 的外键连接
SQL99 写法

select ename,dname,dept.deptno

from dept left outer join emp

on(dept.deptno=emp.deptno);
9I 前的写法

select ename,dname from emp,dept

where emp.deptno(+)=dept.deptno;

SQL> select ename,dname,dept.deptno
  from dept left outer join emp
  on(dept.deptno=emp.deptno);

知识点
1 。笛卡儿连接
2 。等值连接
3 。不等连接
4 。外键连接
5 。自连接

6SQL99的书写格式

实验20:子查询
该实验的目的是掌握子查询的语法和概念 .
  子查询
谁的工资最多

简单子查询
1 。先于主查询执行。
2 。主查询调用了子查询的结果。
3 。注意列的个数和类型要匹配。
4 。子查询返回多行要用多行关系运算操作。
5 。子查询要用括号括起来。

SQL> --查询工资总和高于10号部门工资总和的部门。

SQL> select deptno,sum(sal)

  from emp
  group by deptno

  having sum(sal)>(select sum(sal) from emp where deptno=10);

SQL> -- 查询每个部门的最大工资是谁。

SQL> select deptno,ename,sal from emp

  where (deptno,sal) in

  (select deptno,max(sal) from emp group by deptno);

子查询返回多行,用=不可以,得用in

子查询返回多列,所以对比的列也要匹配。
Any  all 操作

SQL> select ename,sal from emp where sal<any(1000,2000);

小于2000就可以

SQL> select ename,sal from emp where sal<all(1000,2000);

必须小于 1000

小于all小于最小,大于all大于最大

SQL> select ename,sal,deptno from emp

where sal<all(select avg(sal) from emp group by deptno);

小于any小于最大,大于any大于最小

select ename,sal,deptno from emp

where sal>any(select avg(sal) from emp group by deptno)

From 子句中的子查询
查询工资大于本部门平均工资的员工。

select ename,e.deptno,sal,asal

from emp e,

(select deptno ,avg(sal) asal from emp group by deptno) a

where e.deptno=a.deptno and sal>asal;

A为视图,为什么要使用别名asal,因为表达式不能当列的名称,别名的本质使用方法是使非法的合法化。

相互关联的子查询

select ename,sal ,deptno

from emp o

where sal>(select avg(sal) from emp where deptno=o.deptno) ;

先运行主查询,得到第一行,将DEPTNO传入到子查询,由子查询求出AVGSAL),在判定主查询的行是否符合查询的条件。

执行计划是将子查询看作视图的关联。这叫做SQL的自动改写。

Exists 操作

找领导,其中3是常量,你写什么都可以。

当子查询有行时,Exists返回true

查到行后就不再继续查询

当子查询没有行时为假,Exists返回false

select ename,empno,mgr from emp o

where exists(select 3 from emp where mgr=o.empno);

《完》

--xjzhujunjie




本文转自xjzhujunjie 51CTO博客,原文链接:http://blog.51cto.com/xjzhujunjie/868102
相关文章
|
9月前
|
Oracle 关系型数据库 Linux
【赵渝强老师】Oracle数据库配置助手:DBCA
Oracle数据库配置助手(DBCA)是用于创建和配置Oracle数据库的工具,支持图形界面和静默执行模式。本文介绍了使用DBCA在Linux环境下创建数据库的完整步骤,包括选择数据库操作类型、配置存储与网络选项、设置管理密码等,并提供了界面截图与视频讲解,帮助用户快速掌握数据库创建流程。
747 93
|
8月前
|
Oracle 关系型数据库 Linux
【赵渝强老师】使用NetManager创建Oracle数据库的监听器
Oracle NetManager是数据库网络配置工具,用于创建监听器、配置服务命名与网络连接,支持多数据库共享监听,确保客户端与服务器通信顺畅。
407 0
|
11月前
|
存储 Oracle 关系型数据库
服务器数据恢复—光纤存储上oracle数据库数据恢复案例
一台光纤服务器存储上有16块FC硬盘,上层部署了Oracle数据库。服务器存储前面板2个硬盘指示灯显示异常,存储映射到linux操作系统上的卷挂载不上,业务中断。 通过storage manager查看存储状态,发现逻辑卷状态失败。再查看物理磁盘状态,发现其中一块盘报告“警告”,硬盘指示灯显示异常的2块盘报告“失败”。 将当前存储的完整日志状态备份下来,解析备份出来的存储日志并获得了关于逻辑卷结构的部分信息。
|
9月前
|
SQL Oracle 关系型数据库
Oracle数据库创建表空间和索引的SQL语法示例
以上SQL语法提供了一种标准方式去组织Oracle数据库内部结构,并且通过合理使用可以显著改善查询速度及整体性能。需要注意,在实际应用过程当中应该根据具体业务需求、系统资源状况以及预期目标去合理规划并调整参数设置以达到最佳效果。
599 8
|
11月前
|
SQL Oracle 关系型数据库
比较MySQL和Oracle数据库系统,特别是在进行分页查询的方法上的不同
两者的性能差异将取决于数据量大小、索引优化、查询设计以及具体版本的数据库服务器。考虑硬件资源、数据库设计和具体需求对于实现优化的分页查询至关重要。开发者和数据库管理员需要根据自身使用的具体数据库系统版本和环境,选择最合适的分页机制,并进行必要的性能调优来满足应用需求。
502 11
|
11月前
|
Oracle 关系型数据库 数据库
数据库数据恢复—服务器异常断电导致Oracle数据库报错的数据恢复案例
Oracle数据库故障: 某公司一台服务器上部署Oracle数据库。服务器意外断电导致数据库报错,报错内容为“system01.dbf需要更多的恢复来保持一致性”。该Oracle数据库没有备份,仅有一些断断续续的归档日志。 Oracle数据库恢复流程: 1、检测数据库故障情况; 2、尝试挂起并修复数据库; 3、解析数据库文件; 4、导出并验证恢复的数据库文件。
|
11月前
|
存储 Oracle 关系型数据库
【赵渝强老师】Oracle RMAN的目录数据库
Oracle RMAN默认将备份元信息存储在控制文件中,但控制文件损坏或丢失会导致恢复失败,且备份增多会使控制文件无限增长。为解决这些问题,Oracle引入了RMAN目录数据库(Catalog Database),专门用于存储RMAN备份的元信息。使用目录数据库可提升备份管理效率,支持多数据库共享、长期备份历史记录存储,并可保存RMAN脚本。本文详细介绍了如何创建目录数据库、注册目标数据库及其操作步骤。
317 0
|
9月前
|
缓存 关系型数据库 BI
使用MYSQL Report分析数据库性能(下)
使用MYSQL Report分析数据库性能
543 158
|
9月前
|
关系型数据库 MySQL 数据库
自建数据库如何迁移至RDS MySQL实例
数据库迁移是一项复杂且耗时的工程,需考虑数据安全、完整性及业务中断影响。使用阿里云数据传输服务DTS,可快速、平滑完成迁移任务,将应用停机时间降至分钟级。您还可通过全量备份自建数据库并恢复至RDS MySQL实例,实现间接迁移上云。
|
9月前
|
关系型数据库 MySQL 数据库
阿里云数据库RDS费用价格:MySQL、SQL Server、PostgreSQL和MariaDB引擎收费标准
阿里云RDS数据库支持MySQL、SQL Server、PostgreSQL、MariaDB,多种引擎优惠上线!MySQL倚天版88元/年,SQL Server 2核4G仅299元/年,PostgreSQL 227元/年起。高可用、可弹性伸缩,安全稳定。详情见官网活动页。
1431 152

热门文章

最新文章

推荐镜像

更多