亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

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

系統 2761 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條評論
主站蜘蛛池模板: 欧美一区二区在线免费观看 | 999视频在线观看 | 免费网站日本永久免费观看 | 一区二区中文字幕在线观看 | 精品视频在线免费观看 | 97人人澡 | 久久久久久亚洲精品影院 | 五月婷婷六月综合 | 日韩一区二区在线观看 | 激情在线日韩视频免费 | 欧美操片在线观看 | 国产毛片儿 | 亚洲欧洲日韩国产一区二区三区 | 起碰成人免费公开网视频 | 欧美成人一区二免费视频 | 奇米欧美成人综合影院 | 亚洲精品人成在线观看 | 久一视频在线观看 | 中国一级特黄真人毛片免 | 伊人网站在线 | 非洲黑人xxxxxbbbbbb | 色香视频在线 | 99久久久久国产 | 欧美色综合高清免费 | 国产精品久久久久这里只有精品 | 99热这里只有精品在线 | 欧美国产一区二区三区 | 2017天天干天天射 | 麻豆传煤一区免费入 | 亚洲综合91| 九九热只有精品 | 日韩香蕉视频 | 最新国产精品自拍 | 性孕妇video国产中国 | 亚洲成人国产精品 | 日韩 欧美 亚洲 中文字幕 | 一级特黄aa大片欧美小说 | 毛片大片免费看 | 亚洲性夜夜综合久久麻豆 | 国产色资源 | 精品久久久久久中文字幕女 |