SQL子查询

1.子查询是多表查询的一种形式。子查询就是次要查询,它返回的结果数据被用

于主查询的条件中。它返回的结果可以是一行或多行。比如:
例1//返回一条记录
select * 
from emp
where deptno=(select deptno
from dept
where dept_name='SALES')
例2//返回多条记录
select * 
from emp
where deptno in (select deptno
from dept
where dept_addr='北京')
由上例可以看出,子查询并不要求两个表有相关字段,只要得到子查询的结果集

就行,用于主查询,而连接查询,则必须要求两个表有相关字段。

2.连接查询是对两个表逐记录(一行一行地)进行相关查询,例1可写为连接查询

,例2不可以写为连接查询,因为子查询返回多行记录。
select * 
from emp a, dept b
where a.deptno= b.deptno and b.dept_name='SALES'

上述形式为内连接,还有外连接

oracle中的字段后面有加号是什么意思,多说一点详细一点
a.emp_no = b.emp_no (+) 

不论把(+)写在等号左边项还是右边项,统称为外连接内连接中,只返回那些在连接表中有匹配数据的数据行 

外连接即在被连接的表中加入一个空行来与没有匹配行的数据进行匹配 

比如查询员工所属的部门,总裁不属于任何部门,(老板不属于任何部门,dname

项是空的) 

select e.emp_name ename,d.dept_name dname 
from emp e, dept d 
where e.dept_no=d.dept_no(+) 

ename dname 
—————————— 
sam SALES 
tom ACCOUNTING 
king

上述外连接请参看:
http://zhidao.baidu.com/question/44054333.html

3.递归查询可以用来表示相同实体内相互联系的各个数据集间的关系;外连接可以用来连接那些本来没有匹配数据的表;相关子查询显示如何在子查询中使用主查询中的数据来加强查询条件,就是带exists谓词的查询。

建议你看看萨师宣老师的《数据库原理》(高教出版社)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值