ORACLE SQL多表查询

使用连接在多个表中查询数据
在 WHERE 子句中写入连接条件
在表中有相同列时,在列名之前加上表名前缀
(1)等值连接 (=)
(2)非等值连接(in)
例:查询每个员工的 last_name 和 GRADE_LEVEL(在 JOB_GRADES 表中). ---- 非等值连接
Select last_name, salary, grade_level, lowest_sal, highest_sal
From employees e, job_grades j
Where e.salary >= j.lowest_sal and e.salary <= j.highest_sal
(3)外连接
两个表在连接过程中除了返回满足连接条件的行以外还返回左(或右)表中不满足条件的行,这种连接称为左(或右) 外连接。
两个表在连接过程中除了返回满足连接条件的行以外还返回两个表中不满足条件的行 ,这种连接称为满外连接。
(4)自连接
通过一条 sql 查询(自连接):
Select m.*from employees e, employees m
Where e.manager_id = m.employee_id and e.last_name = ‘Chen’
(5)1999语法连接
(6)自然连接
例:
SELECT department_id, department_name, location_id, city
FROM departments
NATURAL JOIN locations;
(7) USING 子句创建连接
• 在NATURAL JOIN 子句创建等值连接时,可以使用 USING 子句指定等值连接中需要用到的列。
• 使用USING可以在有多个列满足条件时进行选择
• 不要给选中的列中加上表名前缀或列名
• JOIN 和USING 子句经常同时使用

(8)使用ON 子句创建连接
• 自然连接中是以具有相同名字的列为连接条件的
• 可以使用ON 子句指定额外的连接条件
• 这个连接条件是与其它条件分开的
• ON子句使语句具有更高的易读性

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值