oracle執行計劃的rows不對,Oracle執行計劃——all_rows和first_rows(n)優化器模式

Oracle執行計劃——all_rows和first_rows(n)優化器模式

0. 環境創建

[sql]

SQL> create usertest identified by test

2 default tablespace users

3 temporary tablespace temp

4 quota unlimited on users;

User created.

SQL> grant createsession, resource, alter session to test;

Grant succeeded.

SQL> conntest/test;

Connected.

SQL> create tableemp(id number, name varchar2(10));

Table created.

SQL> insert intoemp values(100, 'tom');

1 row created.

SQL> insert intoemp values(200, 'mike');

1 row created.

SQL> insert intoemp values(300, 'jack');

1 row created.

SQL> insert intoemp values(400, 'rose');

1 row created.

SQL> commit;

Commit complete.

1. 數據少時的情況

1.1 FIRST_ROWS_10

[sql]

SQL> setautotrace traceonly;

SQL> executedbms_stats.gather_table_stats('TEST', 'emp', cascade=>true);

PL/SQL proceduresuccessfully completed.

SQL> altersession set optimizer_mode=first_rows_10;

Session altered.

194992_0.jpeg

1.2 ALL_ROWS

[sql]

SQL> alter sessionset optimizer_mode=all_rows;

Session altered.

194992_1.jpeg

1.3 分析

通過上面的簡單舉例比較,我們可以看到,在表上沒有索引,當數據量很少,并且值唯一的情況下,兩種模式的表現是一樣的

2. 數據少時的情況

[sql]

SQL> create indexemp_idx on emp(name);

Index created.

SQL> setautotrace off

SQL> insert intoemp select * from emp;

4 rows created.

SQL> insert intoemp select * from emp;

8 rows created.

SQL> /

16 rows created.

SQL> /

32 rows created.

SQL> /

64 rows created.

SQL> /

128 rows created.

SQL> /

256 rows created.

SQL> /

512 rows created.

SQL> /

1024 rows created.

SQL> /

2048 rows created.

SQL> /

4096 rows created.

SQL> /

8192 rows created.

SQL> /

16384 rows created.

SQL> /

32768 rows created.

SQL> commit;

Commit complete.

SQL> executedbms_stats.gather_table_stats('TEST', 'emp', cascade=>true);

PL/SQL proceduresuccessfully completed.

2.1 FIRST_ROWS_10

[sql]

SQL> setautotrace traceonly

SQL> altersession set optimizer_mode=first_rows_10;

Session altered.

194992_2.jpeg

2.2 ALL_ROWS

[sql]

SQL> setautotrace traceonly

SQL> altersession set optimizer_mode=all_rows;

Session altered.

194992_3.jpeg

2.3 分析

我們看到fisrt_rows走了索引,這顯然不是一種理想的結果,而all_rows走了全表掃描,我們可以看到成本明顯更低。

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

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

相關文章

從 MVC 到前后端分離

轉載自:https://my.oschina.net/huangyong/blog/521891 從MVC到前后端分離 1.理解 MVC MVC是一種經典的設計模式,全名為Model-View-Controller,即模型-視圖-控制器。其中,模型是用于封裝數據的載體,例如,在…

leetcode93. 復原IP地址(回溯)

給定一個只包含數字的字符串,復原它并返回所有可能的 IP 地址格式。 有效的 IP 地址正好由四個整數(每個整數位于 0 到 255 之間組成),整數之間用 ‘.’ 分隔。 示例: 輸入: “25525511135” 輸出: [“255.255.11.135”, “255…

vj節點_創意編碼—如何在JavaScript中創建VJ引擎

vj節點by George Gally通過喬治加利 創意編碼—如何在JavaScript中創建VJ引擎 (Creative Coding — How to create a VJ engine in JavaScript) 了解如何將JavaScript動態注入網頁 (Learn how to dynamically inject JavaScript into webpages) For years I’ve been using th…

上傳下載

# 默寫 TCP UDP 文件夾中的代碼# 完成一個上傳和下載文件的小程序 # server端 :根據客戶端需求自定義 # client端 # 客戶端啟動之后 # 選擇 上傳操作 還是 下載操作 # 如果是上傳操作 : 輸入要上傳的文件路徑 # 基礎需求 :直接將文件上傳到默認目錄 # 進階需求 :將…

qt 串口 環形緩存_qt?linux串口?緩沖區多大

滿意答案Zc的愛丶很美2016.09.11采納率:51% 等級:9已幫助:515人一、程序設計的基礎,例如:基本的編程語言基礎,至少對數據類型、程序的結構及流程控制等最基本的內容要相當清楚!另外有不少同學…

在.NET中使用SMTP發送郵件

這是一篇轉載,可能對大家很有用啊,放首頁看看是否有參考價值。本文提到的方案仍然不能算是完全解決所有問題,最佳的dotNET下通過SMTP(帶驗證)發送郵件的機制是什么,不知道大家有什么好的看法! …

oracle堆,oracle被一堆insert和update堵死解決方案

當前位置:我的異常網 Oracle技術 oracle被一堆insert和update堵死解決方案oracle被一堆insert和update堵死解決方案www.myexceptions.net 網友分享于:2014-07-22 瀏覽:0次oracle被一堆insert和update堵死在生產環境下,幾乎每天都會發生一次…

leetcode306. 累加數(回溯)

累加數是一個字符串,組成它的數字可以形成累加序列。 一個有效的累加序列必須至少包含 3 個數。除了最開始的兩個數以外,字符串中的其他數都等于它之前兩個數相加的和。 給定一個只包含數字 ‘0’-‘9’ 的字符串,編寫一個算法來判斷給定輸…

使用Typescript和React的最佳實踐

by Christopher Diggins克里斯托弗迪金斯(Christopher Diggins) 使用Typescript和React的最佳實踐 (Best practices for using Typescript with React) There are numerous tools and tutorials to help developers start writing simple React applications with TypeScript.…

LeetCode || Copy List with Random Pointer

A linked list is given such that each node contains an additional random pointer which could point to any node in the list or null. Return a deep copy of the list. 思路1:最傻瓜的方法是首先遍歷一次建立next關系的新list。然后第二次遍歷處理random關系…

oracle存儲過程多分支怎樣寫,如何從存儲過程返回多行? (Oracle PL / SQL)

如何從存儲過程返回多行? (Oracle PL / SQL)我想用一個參數創建一個存儲過程,該存儲過程將根據參數返回不同的記錄集。 這是怎么做的? 我可以從普通SQL中調用它嗎?5個解決方案65 votes這是如何構建一個函數,該函數返回…

京東布局消費物聯網 聚合產業鏈共建生態

據Gartner發布的數據顯示,到2020年,全球聯網設備數量將達260億臺,物聯網市場規模將達1.9萬億美元。如今,互聯網已經從人與人的連接發展到人與物、物與物的連接,物聯網時代帶來。 5月9日,京東聚合三大運營商…

xshell監聽端口_監聽端口修改_笨辦法學Linux 遠程訪問 (原理、實踐、記錄與排錯)-視頻課程_Linux視頻-51CTO學院...

聰明人下笨功夫。本課程所倡導“笨辦法”的核心是:● 深入理解原理● 精讀man幫助、官方文檔…● 做所有的實驗,盡量不要復制粘貼!● 詳細記錄實驗過程● 使用思維導圖等輔助工具● 享受排錯的過程,在尋求幫助之前先嘗試自己解決本…

leetcode632. 最小區間(堆+多指針)

你有 k 個升序排列的整數數組。找到一個最小區間&#xff0c;使得 k 個列表中的每個列表至少有一個數包含在其中。 我們定義如果 b-a < d-c 或者在 b-a d-c 時 a < c&#xff0c;則區間 [a,b] 比 [c,d] 小。 示例 1: 輸入:[[4,10,15,24,26], [0,9,12,20], [5,18,22,3…

【SLAM】安裝 g2o_viewer

2017年2月8日&#xff0c;那是一個陰天。為了完成高翔博士的《一起做RGB-D SLAM》教程&#xff0c;我在 Ubuntu 14.04 安裝 g2o。遇到困難&#xff0c;怎奈我眼瞎&#xff0c;找錯了方向&#xff0c;浪費時間&#xff0c;沒有成功安裝。 問題如下&#xff08;跳到最后一個問題描…

CSS動畫快速介紹

Interested in learning CSS? Get my CSS Handbook 有興趣學習CSS嗎&#xff1f; 獲取我的CSS手冊 介紹 (Introduction) An animation is applied to an element using the animation property.使用animation屬性將動畫應用于元素。 .container { animation: spin 10s linear…

2_sat

要求字典序的情況的話&#xff0c;爆搜 不要求的話 1:建圖&#xff0c;有向邊A--->B的意義為選擇A則必須選擇B&#xff0c;一般一個點的兩種取值情況會拆點。 2:縮點。 3:建反向圖&#xff0c;跑拓撲排序&#xff08;有說不用建再跑&#xff0c;但我不懂為什么&#xff09;。…

[Spark][Python]Spark 訪問 mysql , 生成 dataframe 的例子:

[Spark][Python]Spark 訪問 mysql , 生成 dataframe 的例子&#xff1a; mydf001sqlContext.read.format("jdbc").option("url","jdbc:mysql://localhost/loudacre")\ .option("dbtable","accounts").option("user&quo…

ffmpeg mac 批量腳本_使用批處理腳本(BAT)調用FFMPEG批量編碼視頻

使用批處理腳本(BAT)編碼視頻非常方便&#xff0c;尤其當視頻序列非常多的時候&#xff0c;更是省了不少簡單重復性勞動。只要學會批處理里面幾個基本的命令就行了&#xff0c;感覺和c/c差不多。set&#xff1a;設置變量(注意&#xff1a;變量一般情況下是字符串&#xff0c;而…

單實例oracle ha,Oracle單實例啟動多個實例

Oracle單實例啟動多個實例多實例運行&#xff0c;單個實例就是一個數據庫&#xff01;一個數據庫對應多個實例是RAC。Linux建立oracle的實例步驟&#xff1a;1、在linux服務器的圖形界面下&#xff0c;打開一個終端&#xff0c;輸入如下的命令&#xff1b; xhost ###遠程調用…