Oracle子查詢過程中值得注意的事項(xiàng)
我們都知道HAVING中我們可以用Oracle子查詢 ,而且兩個(gè)查詢的語句的結(jié)果是可做集合操作的,如果你想知道HAVING中我們是如何使用Oracle子查詢的?以及兩個(gè)查詢的語句的結(jié)果是可做集合的實(shí)際操作是如何進(jìn)行的?以下的內(nèi)容就有相關(guān)的答案。
1. 查詢語句可以嵌套
例如: SELECT …… FROM (SELECT …… FROM表名1, [表名2, ……] WHERE 條件) WHERE 條件2;
2. 何處可用Oracle子查詢?
當(dāng)查詢條件是不確定的條件時(shí)
DML(insert, update,delete)語句里也可用子查詢
HAVING里也可用子查詢
3. 兩個(gè)查詢語句的結(jié)果可以做集合操作
例如:
并集UNION(去掉重復(fù)記錄)
并集UNION ALL(不去掉重復(fù)記錄)
10
J2EE @ zxw
差集MINUS,
交集INTERSECT
4. 子查詢的注意事項(xiàng)
先執(zhí)行括號(hào)里面的SQL語句,一層層到外面
內(nèi)部查詢只執(zhí)行一次
如果里層的結(jié)果集返回多個(gè),不能用= > < >= <=等比較符要用IN.
5. Oracle子查詢的例子(1)
- SQL> select title,avg(salary) from s_emp
- group by title Having avg(salary) =
- (select min(avg(salary)) from s_emp
- group by title);
找到最低平均工資的職位名稱和工資
子查詢的例子(2)
Oracle子查詢可以用父查詢里的表名
這條SQL語句是對(duì)的:
- SQL>select cty_name from city where st_code in
- (select st_code from state where st_name='TENNESSEE' and
- city.cnt_code=state.cnt_code);
說明:父查詢調(diào)用子查詢只執(zhí)行一次.
6.取出結(jié)果集的80 到100的SQL語句
Oracle處理每個(gè)結(jié)果集只有一個(gè)ROWNUM字段標(biāo)明它的邏輯位置,
并且只能 用ROWNUM<100, 不能用ROWNUM>80。
以下是經(jīng)過分析后較好的兩種Oracle取得結(jié)果集80到100間的SQL語句
( ID是唯一關(guān)鍵字的字段名 )
語句寫法:
- SQL>select * from (
- ( select rownum as numrow, c.* from (
- select [field_name,...]
from table_name where 條件1 order by 條件2) c)- where numrow > 80 and numrow <= 100 )
order by 條件3;
以上的相關(guān)內(nèi)容就是對(duì)Oracle子查詢的介紹,望你能有所收獲。
【編輯推薦】