1:等值连接
迪卡尔集连接
select ename, a.deptno as a_deptno,b.deptno as b_deptno ,b.dname as 部门
from emp a, dept b
等值连接
select ename, a.deptno as a_deptno,b.deptno as b_deptno ,b.dname as 部门
from emp a, dept b
where a.deptno = b.deptno;
2:非等值连接,在emp表和salgrade表中查找员工的姓名,工资,等级,工资上线,工资下线
select ename as 姓名, sal as 工资, grade as 工资等级,losal as 工资上线,hisal as 工资下线
from emp, salgrade
where sal between losal and hisal;
3:外连
右外连
select e.ename, d.dname, e.deptno
from emp e,dept d
where e.deptno = d.deptno(+);
左外连与右外连相反
以hr登陆查询表employees 和departments 表
select first_name as 姓名, department_name as 部门名称, d.department_id as 部门编号
from employees e, departments d
where e.department_id= d.department_id(+) ;
4:自连:在同一个表中查询每个员工及上司的工号和姓名
select a.empno as 员工编号, a.ename as 员工姓名, a.mgr as 上司的员工编号, b.ename as 上司姓名
from emp a, emp b
where a.mgr = b.empno;
5:sql99
交叉连接 cross join------相当于迪卡尔集
select e.ename,d.dname
from emp e cross join dept d;
自然连接 natural join------相当等值连接
select e.ename, d.dname
from emp e natural join dept d;
using子句-----使用同名列查询
select e.ename, d.dname
from emp e join dept d
using (deptno);
on子句 ------当列名不同时用on子句
用on查询两张表
select e.ename, d.dname
from emp e join dept d
on e.deptno = d.deptno;
用on查询多张表
select e.ename, d.dname
from emp e join dept d
on e.deptno = d.deptno
join 第三个表
on 列1 = 列2;
内连接(Inner join)-------内连接只返回满足连接条件的数据
select employee_id, last_name, salary, department_id, department_name
from employees inner join departments using(department_id);
左外连
select employee_id, last_name, salary, department_id, department_name
from employees left join departments using(department_id);
右外连
select employee_id, last_name, salary, department_id, department_name
from employees right join departments using(department_id);
满外连
select employee_id, last_name, salary, department_id, department_name
from employees full outer join departments using(department_id);
子查询------------
查找出工资比scott高的人
select ename, sal from emp
where sal>
(select sal from emp where ename='SCOTT');
查找那些人和scott相同职位的人
select ename, job from emp
where job=
(select job from emp where ename='SCOTT')
and ename <> 'SCOTT';
any的用法 < any意味着小于最大、> any大于最小
select empno, ename, sal, job
from emp
where sal<any(select sal from emp where job='SALESMAN');
all的用法 < all:小于所有,即小于最小、> all:大于所有,即大于最大
select empno, ename, sal, job
from emp
where sal<all(select sal from emp where job='SALESMAN');
相关推荐
oracle sql 多表连接和子查询 oracle sql 多表连接和子查询
oracle表连接和子查询实例 所有的实例查询都包含在里面,不会担心笔试oracle子查询。
ORACLE_多表连接与子查询2[定义].pdf
oracle select group 子查询 表连接
这个非常经典的oracle数据库的操作,查询和视图,PLSQL介绍,存储过程和触发器的详细PPT讲解,希望对大家有所帮助,挺经典的。
数据库开发 Oracle数据库 SQL开发教程 第05章 多表连接(共48页).pdf 数据库开发 Oracle数据库 SQL开发教程 第06章 分组函数(共41页).pdf 数据库开发 Oracle数据库 SQL开发教程 第07章 子查询(共49页).pdf ...
数据库开发 Oracle数据库 SQL开发教程 第05章 多表连接(共48页).pdf 数据库开发 Oracle数据库 SQL开发教程 第06章 分组函数(共41页).pdf 数据库开发 Oracle数据库 SQL开发教程 第07章 子查询(共49页).pdf ...
数据库开发 Oracle数据库 SQL开发教程 第05章 多表连接(共48页).pdf 数据库开发 Oracle数据库 SQL开发教程 第06章 分组函数(共41页).pdf 数据库开发 Oracle数据库 SQL开发教程 第07章 子查询(共49页).pdf ...
数据库开发 Oracle数据库 SQL开发教程 第05章 多表连接(共48页).pdf 数据库开发 Oracle数据库 SQL开发教程 第06章 分组函数(共41页).pdf 数据库开发 Oracle数据库 SQL开发教程 第07章 子查询(共49页).pdf ...
10.1.1 在多表查询中使用子查询 10.1.2 在子查询中使用聚合函数 10.2 创建和使用返回多行的子查询 10.2.1 IN子查询 10.2.2 IN子查询实现集合交和集合差运算 10.2.3 EXISTS子查询 10.2.4 EXISTS子...
之间的连接条件置于其他WHERE子句之前,即对易排查的条件先做判断处理,这样在过滤掉尽可能多的记录后再进行等值连接,可以提高检索效率。 例如: SELECT empno, ename, job, sal, dept.deptno, dname FROM emp, ...
第六章 子查询 第七章 数据建模及数据库设计 了解系统开发的步骤 数据关系的定义 理解实体关系映射图(E-R图) 第八章 创建表 掌握创建表的语法 Oracle的数据类型 使用约束 第九章 对数据的操作 在已创建表中插入...
2. Oracle介绍与安装 2.1 Oracle安装 2.2 Oracle 默认用户 2.3 服务器连接 3. PL/SQL Developer工具 4. Oracle用户和权限 4.1用户和权限 4.2角色 第2章 SQL数据操作和查询 1. SQL简介 2. 查询 2.1查询...
1.简单查询 2.时间函数 3.分组查询 4.多表查询 5.多表连接 6.子查询 7.创建和管理表 8.约束 9.视图,序列,索引 10.pI sql 基础
Oracle数据库概述 简单SQL语句 SQL中的函数 多表连接和子查询 数据操纵 数据库对象
数据库开发 Oracle数据库 SQL开发教程 第05章 多表连接(共48页).pdf 数据库开发 Oracle数据库 SQL开发教程 第06章 分组函数(共41页).pdf 数据库开发 Oracle数据库 SQL开发教程 第07章 子查询(共49页).pdf ...
介绍了PL/SQL中常用的函数、异常处理等,还有对随机数生成、分析函数、多表合并、多表插入等问题的解决方法。第7章 子程序和触发器,包括函数、存储过程、包以及触发器等。对子程序的调用者权限、管道表函数、传递...
第三章 Sql查询与函数 一、 SQL概述 SQL(Structured Query Language)结构化查询语言,是一种数据库查询和程序设计语言,用于存取数据以及查询、更新和管理关系数据库系统。同时也是数据库脚本文件的扩展名。 SQL...
子查询和常用函数 48 1. 子查询 49 2. Oracle中的伪列 51 3. Oracle函数 54 4. 本章总结 62 5. 本章练习 63 表空间、数据库对象 66 1. Oracle数据库对象 67 2. 同义词 67 3. 序列 70 4. 视图 72 5. 索引 74 6. 表...