复杂oracle sql查询语句,oracle中复杂sql查询语句详解(1/4)

本文介绍了如何使用SQL的子查询从多个表中检索数据,特别是相关子查询在WHERE子句中的应用。通过示例展示了如何找出既以研究所又以大学系名义申请项目的专家,强调了子查询在条件过滤中的作用,同时提醒注意嵌套层数过多可能对性能的影响。

1.查询语句的使用

使用 select语句和子查询(subquery)可以从一个或多个表,视图,实体试图中返回数据.

1.1相关子查询

可以将子查询(as subquery)或in或exists当成where的一个条件的一部分,这样的查询称为子查询

.where中可以包含一个select语句的子查询

.where中可以包含in,exists语句

.最多可以嵌套16层

.层次过多会影响性能

[例]简单子查询实例

查询是否有的专家既以研究所的名义来申请基金项目,又以大学系为单位申请项目

(按规定只能以一个单位来申请)

sql> create table univ_subject

2 (

3 name varchar2(12) not null,

4 per_id number not null,

5 dept_name varchar2(20)

6 );

sql> insert into univ_subject values('gaoqianjing',1001,'信息工程系');

sql> insert into univ_subject values('wangbing',1002,'物理系');

sql> insert into univ_subject values('liming',1003,'化学系');

===============

sql> create table colle_subject

2 (

3 colle_name varchar2(20),

4 per_id number

5 );

sql> insert into colle_subject values('电子研究所',1001);

sql> insert into colle_subject values('物理研究所',1005);

================

sql> select name,per_id,dept_name from univ_subject where per_id in

2 (select per_id from colle_subject);

name per_id dept_name

------------ --------- --------------------

gaoqianjing 1001 信息工程系 本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:php中文网

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值