Oracle第五章笔记

第五章 多表连接

  • 什么是连接?
  • 通过一定的条件, 是表发生关联
1. 使用一条sql语句, 查询员工姓名, 部门名称, 共工作地
   select ename, dname, loc
   from emp, dept
   where emp.deptno = dept.deptno;n
   
2. 可以起别名, 标识关键字, 使用别名
   --注意: 为表起别名时, 不能使用as 关键字
   select ename, dname, loc
   from emp e, dept d
   where e.deptno=d.deptno;
   
3. 笛卡尔积 在进行表连接时, 没有指定连接条件
-- 如果左表有n条记录,右表有m条记录,笛卡尔积查询出有n*m条记录,
--其中往往包含了很多错误的数据,所以这种查询方式并不常用
select * from emp, dept;

内连接

内连接查询操作列出与连接条件匹配的数据行,
结果集中不包括一个表与另一个表不匹配的行。 

1. 等值连接

0.查询10号部门的员工姓名, 部门名称, 工作地点
 select e.ename, d.dname, d.loc
 from emp e, dept d 
 where e.deptno = d.deptno and e.deptno = 10;
 
1.写一个查询, 显示所有员工姓名, 部门编号, 部门名称
 select e.ename, d.deptno, d.dname 
 from emp e, dept d 
 where e.deptno = d.deptno;

2.写一个查询, 显示所有工作地点在CHICAGO并且奖金不为空的员工姓名, 工作地点, 奖金
 select e.ename, d.loc, e.comm 
 from emp e, dept d 
 where e.deptno = d.deptno 
 and d.loc = 'CHICAGO' 
 and e.comm is not null;

3.写一个查询, 显示所有姓名中含A字符的员工工作姓名,
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值