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

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

系統(tǒng) 2433 0

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

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

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

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

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

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

[Oracle]高效的PL/SQL程序設(shè)計(jì)(六)--%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é)果會(huì)有些許差別,主要在all_objects沒有符合條件的行時(shí), 外部連接的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. 多個(gè)聚合函數(shù)的使用技巧

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

(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)建對(duì)象類型

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è)計(jì)(二)--標(biāo)量子查詢


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

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號(hào)聯(lián)系: 360901061

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

【本文對(duì)您有幫助就好】

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

發(fā)表我的評(píng)論
最新評(píng)論 總共0條評(píng)論
主站蜘蛛池模板: 婷婷四房综合激情五月在线 | 免费视频网站一级人爱视频 | 欧美日韩视频一区三区二区 | 亚洲国产精品综合福利专区 | 国产成人精品高清免费 | 99热这里只有精品6免费 | 亚洲另类视频在线观看 | 精品哟哟国产在线观看 | 一级做a爱片久久蜜桃 | 华人欧美国产在线精品 | 色综久久天天综合绕视看 | www.亚洲一区二区三区 | 九九精品激情在线视频 | 亚洲香蕉毛片久久网站老妇人 | 久久在线免费 | 四虎影视在线播放 | 国产性较精品视频免费 | 日本无翼乌全彩无遮挡动漫 | 久久这里只精品 | 成人国产欧美精品一区二区 | 日韩欧美一中字暮 | 久久视频在线观看免费 | 四虎国产精品视频免费看 | 国产青草 | 香蕉视频黄在线观看 | 国产精品永久在线 | 亚洲精品久久久久久下一站 | 国产日韩欧美一区二区三区综合 | 亚洲欧美色综合精品 | 久久精品国内一区二区三区 | 久久国产精品亚洲va麻豆 | 亚洲久热 | 五月四房婷婷 | 99久久精品费精品国产一区二 | 欧美一区二区精品 | 国产青草 | 日韩欧美在线不卡 | 成人久久精品 | 久久99亚洲精品久久久久 | 日韩免费福利视频 | 在线看欧美三级中文经典 |