oracle標量子查詢的優勢,標量子查詢

--標量子查詢

select e.empno, e.ename, e.sal, e.deptno,

(select d.dname from dept d where e.deptno = d.deptno)as dname

from emp e

--插入一條數據

insert into emp(empno,deptno) values(9999,null)--返回結果15條記錄

--改成left join(hash outer)

select e.empno, e.ename, e.sal, e.deptno,d.dname

from emp e

left join dept d

on (e.deptno = d.deptno)

--NL outer

select /*+ use_nl(e,d) */e.empno, e.ename, e.sal, e.deptno,d.dname

from emp e

left join dept d

on (e.deptno = d.deptno)

/*Note:修改后plan一般有outer字樣,如果沒有,注意是否改錯。*/

--用left join 優化標量子查詢之聚合改寫

select dp.department_id, dp.department_name, dp.location_id,

nvl((select sum(em.salary)

from hr.employees em

where em.department_id = dp.department_id),

0) as sum_dept_salary

from hr.departments dp

--錯誤寫法

select dp.department_id, dp.department_name, dp.location_id,

nvl(sum(em.salary), 0) as sum_sal

from hr.departments dp

left join hr.employees em

on dp.department_id = em.department_id

--原標量子查詢改寫為:

select em.department_id, sum(em.salary) as sum_sal

from hr.employees em

group by em.department_id

--左聯改寫后的內聯視圖

select dp.department_id, dp.department_name, dp.location_id,

nvl(sum(e.sum_sal), 0) as sum_sal

from hr.departments dp

left join (select e.department_id, sum(e.salary) as sum_sal

from hr.employees e

group by e.department_id) e

on (dp.department_id = e.department_id)

group by dp.department_id, dp.department_name, dp.location_id

--

create table dept2 as select * from scott.dept;

insert into dept2? select * from scott.dept where deptno=10

select t1.job, t1.deptno,

(select distinct dname from dept2 b where b.deptno = t1.deptno) as dname

from scott.emp t1

order by 1, 2, 3

--以下改寫結果變了

select distinct t1.job, b.deptno, b.dname

from scott.emp t1

left join dept2 b

on t1.deptno = b.deptno

--正確改寫

select t1.job, t1.deptno, f.dname

from scott.emp t1

left join (select b.deptno, b.dname

from dept2 b

group by b.deptno, b.dname) f

on (f.deptno = t1.deptno)

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/533013.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/533013.shtml
英文地址,請注明出處:http://en.pswp.cn/news/533013.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

切割照片php上傳,php下ajax的文件切割上傳

var myForm document.getElementById("myForm");var upfile document.getElementById("upfile");myForm.onsubmit function() {//獲取文件對象var file upfile.files[0];//獲取文件大小var fileSize file.size;//一次截取的大小(字節)var CutSize 10…

oracle插補缺失日期,Oracle連接 ORA-28001: 口令已經失效解決方法

cmd進入命令行C:UsersAdministrator>sqlplus / as sysdbaSQL*Plus: Release 11.2.0.1.0 Production on 星期四 9月 24 15:19:21 2020Copyright (c) 1982, 2010, Oracle. All rights reserved.連接到:Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Pr…

PHP 蒙太奇馬賽克拼圖,AndreaMosaic制作一幅馬賽克拼圖

大家在網上應該都見過用很多幅圖片拼成的馬賽克圖片,今天小編就為大家介紹AndreaMosaic制作一幅馬賽克拼圖方法,不會的朋友快快來學習吧!軟件名稱:AndreaMosaic(蒙太奇圖片制作軟件) V6.1.0.4 中文安裝免費版軟件大小:…

php mongo 查詢count,[PHP] 使用PHP在mongodb中進行count查詢

原文:https://www.cnblogs.com/taoshihan/p/12362111.html在php7的mongodb擴展中,當要查詢某個集合在某個條件下的數據個數時,可以使用下面的方式來獲取。比原生的命令要復雜許多比舊版mongo擴展也復雜許多需要使用到MongoDB\Driver\Command …

oracle字段類型設計,Oracle字段類型設計與實際業務不符引發的問題

在Oracle表的設計過程中,開發人員總是對字段的類型不以為然,下面來演示一個例子,按照應該設計為number的,結果設計成了varcha在Oracle表的設計過程中,開發人員總是對字段的類型不以為然,下面來演示一個例子…

linux下進程監控6,Linux進程監控技術—精通軟件性能測試與LoadRunner最佳實戰(6)...

8.2.5 Linux操作系統進程監控技術Linux在進程監控方面同樣出色,不僅可以通過圖形用戶界面的管理工具,還可以用命令方式顯示進程相關信息。像“Windows的任務管理器”一樣,在RedHat 9中可以通過單擊“系統工具”→“系統監視器”,…

linux pcie命令,setpci命令_Linux setpci 命令用法詳解:查詢和配置PCI設備的使用工具...

setpci命令是一個查詢和配置PCI設備的使用工具。語法setpci(選項)(參數)選項-v:顯示指令執行的細節信息;-f:當沒有任何操作需要完成時,不顯示任何信息;-D:測試模式,并不真正將配置信息寫入寄存器…

linux proc文件 write的原子性,Linux命令之write調用的原子性

linux命令是對Linux系統進行管理的命令。本文介紹的關于linux命令中write調用的原子性的詳細描述,具體內容如下所述。UNIX環境高級編程中關于原子操作的介紹,其中有一種情形是在文件尾端添加數據。文中說,如果多個進程都需要將數據添加到某一…

linux 命令行 迅雷替代,Mac/Linux下迅雷替代方案

還記得我兩年前寫的《DIY了家用NAS》嗎?現在又帶來新的升級啦。當初的NAS最多能使用Transmission來進行BT下載,那時就在想,如果能下載普通的http資源就好了。再進一步,有什么方案可以通吃所有下載方式呢? 記得那個時候…

linux好用的編譯器,推薦幾款Linux下比Notepad++好的編輯器軟件

Notepad這一段又出風頭了,好好的做你軟件多好,非得參雜入政治。前兩天開源文本編輯器 Notepad 發布了 7.8.1 版本,然后在該版本中作者居然摸黑中國,具體的內容請大家自行百度。而且這已經不是 Notepad 第一次這么干了!…

linux下調用python腳本,Linux下QT調用Python腳本的解決方案,Qt,python,一種,解決辦法

最近在做一個深度學習對圖片中對象識別效果的檢測工具,其主要功能就是將自己標注的圖片與識別結果圖片進行對比然后計算識別的準確等參數,并提供原圖與結果圖片的顯示功能。腳本主要完成識別與計算功能,QT完成數據的整理顯示與圖片的顯示。我…

linux獲取bind返回值信息,v$sql_bind_capture 獲取綁定變量信息

截取自v$sql_bind_capture 對于游標中定義的每一個綁定變量都會有視圖中的一行對應。主要包含三個部分:指向父游標(hash_value, address)和子游標(hash_value, child_address)的信息,變量類型定義,變量的值(不包含復雜的值:LONG,LOB,和…

linux boost教程,Linux上安裝使用Boost入門指導

獲得boostboost分布只需要頭文件的庫使用boost建立一個簡單的程序準備使用boost二進制文件庫把你的程序鏈接到boost庫1.獲得boost解壓2.boost分布boost_1_46_1.........................boost根目錄boost/.....................................所有boost頭文件libs/..........…

vps如何linux內核4.19,Linux kernel 4.19 RC1 發布,一個相當大的版本

原標題:Linux kernel 4.19 RC1 發布,一個相當大的版本Linus Torvalds今天發布了第一個候選版本(RC),正式啟動了即將推出的Linux 4.19內核系列的開發周期。自Linux 4.18內核系列推出以來已經過去兩周了,因此下一個主要版本Linux ke…

linux下變量名長度,Linux中shell的變量介紹

Linux中shell的變量介紹發布時間:2020-06-24 16:20:39來源:億速云閱讀:112作者:元一這期內容當中的小編將會給大家帶來有關Linux中shell的變量介紹,以專業的角度為大家分析和敘述,閱讀完這篇文章希望大家可…

0 0/2 * * * ? linux文本含義,Linux基礎2.0

1、硬盤使用的步驟識別硬盤 > 分區規劃 > 格式化 > 掛載使用2、列出創建ext3、ext4、xfs、fat32文件系統的格式化工具及用法mkfs.ext3 分區設備路徑mkfs.ext4 分區設備路徑mkfs.xfs 分區設備路徑mkfs.vfat -F 32 分區設備路徑3、開機自動掛載配置文件及6個字段/etc/fs…

linux如何加載鏡像,linux可以加載iso鏡像文件到啟動項嗎

該樓層疑似違規已被系統折疊 隱藏此樓查看此樓樓主的需求描述不清,不作評述。只說下關于樓上一些吧友提到的grub loopback設備可mount iso并讀取其中文件的功能未讀過grub1/2的源碼,不太了解其實現原理,但從應用上來說,這個設備不…

10個linux awk文本處理經典案例,關于AWK的10個經典案例

1、分析訪問日志(Nginx為例)日志格式: $remote_addr - $remote_user [$time_local] "$request" $status $body_bytes_sent "$http_referer" "$http_user_agent" "$http_x_forwarded_for" 統計訪問IP次數: # awk…

arm linux 存儲,linux arm的存儲分布那些事

原標題:linux arm的存儲分布那些事linux arm 內存分布總覽上圖是linux的arm的虛擬地址分布總覽,我們按從低地址到高地址的順序逐個描述,每項的描述包括如下的內容的組和:地址范圍大小,虛擬轉物理的接口函數&#xff0c…

linux恢復終端默認配置,以gnome-terminal為例,修改gnome3 的默認配置,

以gnome-terminal為例,修改gnome3 的默認配置,gnome連續幾個版本的terminal默認配置文件都是同一個配置文件“b1dcc9dd-5262-4d8d-a863-c897e6d979b9”。這是因為gnome的developers編輯了這個配置文件并作為gnome-terminal的默認配置文件,用來…