Oracle快速入门(多表查询大全),java面试场景设计题

这篇博客深入探讨Oracle数据库的查询操作,包括隐式内连接、显示内连接、左外连接、右外连接、单行与多行子查询的使用,以及如何在面试中设计相关场景题。通过实例详细解析了各种连接类型和子查询的应用,适合Java开发者和面试者学习提高。
摘要由CSDN通过智能技术生成
1、隐式内连接
(1)等值内连接:

select * from emp,dept where emp.deptno = dept.deptno;

在这里插入图片描述

(2)不等值内连接:

select * from emp,dept where emp.deptno <> dept.deptno;

在这里插入图片描述

(3)自连接:自己连接自己
  • 查询员工编号,员工姓名,经理的编号,经理的姓名

在emp表当中有这样的对应关系

在这里插入图片描述

select e1.empno,e1.ename,e1.mgr,m1.ename from emp e1,emp m1 where e1.mgr = m1.empno;

在这里插入图片描述

  • 查询员工编号,员工姓名,员工部门名称,经理的编号,经理的姓名

在这里插入图片描述

select e1.empno,e1.ename,d1.dname,e1.mgr,m1.ename

from emp e1,emp m1,dept d1 where e1.mgr = m1.empno and e1.deptno = d1.deptno;

在这里插入图片描述

  • 查询员工编号,员工姓名,员工部门名称,经理的编号,经理的姓名,经理的部门名称

在这里插入图片描述

select e1.empno,e1.ename,d1.dname,e1.mgr,m1.ename,d2.dname

from emp e1,emp m1,dept d1,dept d2

where e1.mgr = m1.empno

and e1.deptno = d1.deptno

and m1.deptno = d2.deptno

在这里插入图片描述

  • 查询员工编号,员工姓名,员工部门名称,员工的工资等级,经理的编号,经理的姓名,经理的部门名称

工资等级表

select * from salgrade;

在这里插入图片描述

在这里插入图片描述

select e1.empno,e1.ename,d1.dname,e1.sal,s1.grade,e1.mgr,m1.ename,d2.dname

from emp e1,emp m1,dept d1,dept d2,salgrade s1

where e1.mgr = m1.empno

and e1.deptno = d1.deptno

and m1.deptno = d2.deptno

and e1.sal between s1.losal and s1.hisal;

在这里插入图片描述

  • 查询员工编号,员工姓名,员工部门名称,员工的工资等级,经理的编号,经理的姓名,经理的部门名称,经理的工资等级

select e1.empno,e1.ename,d1.dname,e1.sal,s1.grade,e1.mgr,m1.ename,d2.dname,m1.sal,s2.grade

from emp e1,emp m1,dept d1,dept d2,salgrade s1,salgrade s2

where e1.mgr = m1.empno

and e1.deptno = d1.deptno

and m1.deptno = d2.deptno

and e1.sal between s1.losal and s1.hisal

and m1.sal between s2.losal and s2.hisal;

在这里插入图片描述

  • 查询员工编号,员工姓名,员工部门名称,员工的工资等级,经理的编号,经理的姓名,经理的部门名称,经理的工资等级,将工资等级数字1,2,3,4,显示
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值