Oracle查看SQL執行計劃,分析SQL性能

来源:https://www.cnblogs.com/zdmd/archive/2020/06/13/13114730.html
-Advertisement-
Play Games

如何查看SQL執行計劃 使用 PL/SQL 查看,具體使用方法如下: 新建 解釋計劃視窗 ,將 SQL 複製進去執行,即可顯示執行計劃。 選中 SQL 語句,點擊菜單 工具-解釋計劃 或 按快捷鍵 F5 執行計劃結果說明 表掃描 table access by index rowid 通過ROWID ...


如何查看SQL執行計劃

    使用 PL/SQL 查看,具體使用方法如下:

  • 新建 解釋計劃視窗 ,將 SQL 複製進去執行,即可顯示執行計劃。
    解釋計劃視窗

  • 選中 SQL 語句,點擊菜單 工具-解釋計劃 或 按快捷鍵 F5

執行計劃結果說明

表掃描

table access by index rowid

通過ROWID的表存取,一次I/O只能讀取一個數據塊。通過rowid讀取表欄位,rowid可能是索引鍵值上的rowid

table access full

全表掃描,對所有表中記錄進行掃描。表欄位不涉及索引時往往採用這種方式,此時效率最低。

索引掃描

index unique scan

索引唯一掃描,如果表欄位有 UNIQUEPRIMARY KEY 約束,Oracle實現索引唯一掃描,這種掃描方式條件比較極端,出現比較少。

index range scan

索引範圍掃描,最常見的索引掃描方式。在非唯一索引上都使用索引範圍掃描,具體如下:

  • 在唯一索引列上使用了以下圈定範圍的操作符(> < <> >= <= between等)
  • 在組合索引上,只使用部分列進行查詢,導致查詢出多行
  • 對非唯一索引列上進行的任何查詢
index full scan

索引全掃描,這種情況下,是查詢的數據都屬於索引欄位,一般都含有排序操作。

index fast full scan

索引快速掃描,如果查詢的數據都屬於索引欄位,並且沒有進行排序操作,那麼是屬於這種情況。條件比較極端,出現比較少。

index range scan

索引範圍掃描,最常見的索引掃描方式。在非唯一索引上都使用索引範圍掃描。

index range scan

索引範圍掃描,最常見的索引掃描方式。在非唯一索引上都使用索引範圍掃描。

表連接

排序合併連接(Sort Merge Join)
  • 對於非等值連接,這種連接方式的效率是比較高的。

  • 如果在關聯的列上都有索引,效果更好。

  • 對於將2個較大的row source做連接,該連接方法比Nested Loops連接要好一些。

  • 但是如果sort merge返回的row source過大,則又會導致使用過多的rowid在表中查詢數據時,資料庫性能下降,因為過多的I/O.

嵌套迴圈(Nested Loops)
  • 如果driving row source(外部表)比較小,並且在inner row source(內部表)上有唯一索引,或有高選擇性非唯一索引時,使用這種方法可以得到較好的效率。

  • NESTED LOOPS有其它連接方法沒有的的一個優點是:可以先返回已經連接的行,而不必等待所有的連接操作處理完才返回數據,這可以實現快速的響應時間。

哈希連接(Hash Join)
  • 這種方法是在oracle7後來引入的,使用了比較先進的連接理論,一般來說,其效率應該好於其它2種連接,但是這種連接只能用在CBO優化器中,而且需要設置合適的hash_area_size參數,才能取得較好的性能。

  • 在2個較大的row source之間連接時會取得相對較好的效率,在一個row source較小時則能取得更好的效率。

  • 只能用於等值連接


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 單行編輯控制項具有ES_密碼樣式。預設情況下,具有此樣式的編輯控制項為用戶鍵入的每個字元顯示一個星號。 但是,本例使用EM_SETPASSWORDCHAR消息將預設字元從星號更改為加號(+)。以下屏幕截圖顯示用戶輸入密碼後的對話框。 步驟1:創建密碼對話框的實例。 下麵的C++代碼示例使用DealBox ...
  • 最近安裝了datagrip操作達夢資料庫,發現有一個問題:dagagrip無法獲取dbms_output的輸出,在oracle是可以的,但在達夢不行。 於是聯想到一個問題:c語言裡面怎麼獲取dbms_output的輸出? 百度了一下,沒有找到明確的答案,但是找到了jdbc獲取dbms_output輸 ...
  • 安裝達夢windows版資料庫時,會附帶安裝一個資料庫管理工具。這個工具是我知道的,最全面的達夢資料庫可視化數據操作工具。、 除了支持常規的dml操作外,還支持存儲過程開發與調試,同時提供了簡單的操作歷史記錄查詢,sql自動補全,資料庫對象管理等功能。 但用慣了oracle的人,可能還是會更習慣PL ...
  • 文章開始啰嗦兩句,寫到這裡共21篇關於redis的瑣碎知識,沒有過多的寫編程過程中redis的應用,著重寫的是redis命令、客戶端、伺服器以及生產環境搭建用到的主從、哨兵、集群實現原理,如果你真的能看的進去,相信對你在以後用到redis時會有一定的幫助。 寫到現在,redis相關的內容暫時告一段落 ...
  • 《大話資料庫》-SQL語句執行時,底層究竟做了什麼小動作? 前言 大家好,我是Taoye,試圖用玩世不恭過的態度對待生活的Coder。 現如今我們已然進入了大數據時代,無論是業內還是業外的朋友,相信都有聽說過資料庫這個名詞。數據是一個項目的精華,也扮演著為企業創造價值的重要角色,一個較為完善的公司一 ...
  • 該文章,GitHub已收錄,歡迎老闆們前來Star! GitHub地址: https://github.com/Ziphtracks/JavaLearningmanual 資料庫範式 一、什麼是資料庫範式 設計關係資料庫時,遵從不同的規範要求,設計出合理的關係型資料庫,這些不同的規範要求被稱為不同的 ...
  • 代碼潔癖狂們!看到一個類中有幾十個if-else是不是很抓狂? 設計模式學了用不上嗎?面試的時候問你,你只能回答最簡單的單例模式,問你有沒有用過反射之類的高級特性,回答也是否嗎? 這次就讓設計模式(模板方法模式+工廠模式)和反射助你消滅if-else! 真的是開發中超超超超超超有用的乾貨啊! 那個坑 ...
  • redis 的集合是無序的,集合成員是唯一的,不能重覆。用戶可以快速地對集合執行添加元素操作、移除元素操作以及檢查一個元素是否存在於集合中。這裡介紹一些常用的集合處理命令,併在 Yii 中的使用。 SADD SADD:SADD key-name item [item …]將一個或多個元素添加到集合里 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...