日韩久久久精品,亚洲精品久久久久久久久久久,亚洲欧美一区二区三区国产精品 ,一区二区福利

[Oracle]高效的PL/SQL程序設計(二)--標量子查詢

系統 2643 0

本系列文章導航

[Oracle]高效的PL/SQL程序設計(一)--偽列ROWNUM使用技巧

[Oracle]高效的PL/SQL程序設計(二)--標量子查詢

[Oracle]高效的PL/SQL程序設計(三)--Package的優點

[Oracle]高效的PL/SQL程序設計(四)--批量處理

[Oracle]高效的PL/SQL程序設計(五)--調用存儲過程返回結果集

[Oracle]高效的PL/SQL程序設計(六)--%ROWTYPE的使用

標量子查詢

ORACLE允許在select子句中包含單行子查詢, 使用標量子查詢可以有效的改善性能,當使用到外部連接,或者使用到了聚合函數,就可以考慮標量子查詢的可能性

1. 取消外部連接的使用

外部連接的做法:

select a.username, count ( * ) from all_usersa,all_objectsb
where a.username = b.owner( + )
group by a.username;

改成標量子查詢的做法:

select a.username,( select count ( * ) from all_objectsb where b.owner = a.username)cnt
from all_usersa;

PS: 兩種做法得到的結果會有些許差別,主要在all_objects沒有符合條件的行時, 外部連接的count(*)=1,而標量子查詢的count(*)結果=0

select a.username, count ( * ), avg ( object_id ) from all_usersa,all_objectsb
where a.username = b.owner( + )
group by a.username;

2. 多個聚合函數的使用技巧

當同時出現count(*)/avg()時,不適合在select子句中調用兩次子查詢,性能上會受到影響, 可以改用下面兩種做法

(1).拼接之后再拆分

select username,to_number(substr(data, 1 , 10 ))cnt,to_number(substr(data, 11 )) avg from
(
select a.username,( select to_char( count ( * ), ' fm0000000009 ' ) || avg ( object_id ) from all_objectsb where b.owner = a.username)data
from all_usersa
)

(2).創建對象類型

create or replace typemyType as object
(cnt
number , avg number );

select username,a.data.cnt,a.data. avg from
(
select username,( select myType( count ( * ), avg ( object_id )) from all_objectsb where b.owner = a.username)data
from all_usersa
)a;

博文來源: http://blog.csdn.net/huanghui22/archive/2007/04/30/1593263.aspx

[Oracle]高效的PL/SQL程序設計(二)--標量子查詢


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 江陵县| 海门市| 太康县| 双桥区| 靖州| 大悟县| 黄石市| 泸州市| 彭水| 鞍山市| 那坡县| 洞头县| 鹰潭市| 大冶市| 临沧市| 洪雅县| 伊宁县| 玉屏| 彰化市| 息烽县| 奈曼旗| 泰顺县| 南充市| 海淀区| 惠来县| 隆化县| 琼结县| 渝中区| 琼中| 项城市| 林口县| 乌兰县| 三江| 孙吴县| 高平市| 福州市| 大洼县| 浠水县| 惠安县| 合水县| 淄博市|