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

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

系統(tǒng) 2772 0

本系列文章導(dǎo)航

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

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

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

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

[Oracle]高效的PL/SQL程序設(shè)計(五)--調(diào)用存儲過程返回結(jié)果集

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

標(biāo)量子查詢

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

1. 取消外部連接的使用

外部連接的做法:

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

改成標(biāo)量子查詢的做法:

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

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

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

2. 多個聚合函數(shù)的使用技巧

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

(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).創(chuàng)建對象類型

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程序設(shè)計(二)--標(biāo)量子查詢


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

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

【本文對您有幫助就好】

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

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 陕西省| 仁寿县| 玉田县| 襄樊市| 平阳县| 余江县| 曲阳县| 尚志市| 东城区| 凉山| 增城市| 贵溪市| 紫金县| 新田县| 平泉县| 鄢陵县| 曲麻莱县| 土默特左旗| 图木舒克市| 上思县| 梅河口市| 大荔县| 大厂| 登封市| 滦平县| 牙克石市| 常德市| 苏尼特左旗| 根河市| 西华县| 金溪县| 宝丰县| 上蔡县| 乐至县| 依兰县| 砚山县| 义马市| 万荣县| 香港| 潞城市| 镇安县|