[20190823]关于CPU成本计算3.txt

--//前几天探究CPU cost时遇到的问题,获取行成本时我的测试查询结果出现跳跃,不知道为什么,感觉有点奇怪,分析看看。
--//ITPUB原始链接已经不存在,我的日记本还有记录,现在想想当时的记录思路很乱,不过这些都是猜测的过程,以前思路混乱也是正常的。
--//顺便做一些必要补充唯一索引的相关CPU COST。

1.环境:
SCOTT@test01p> @ ver1
PORT_STRING          VERSION    BANNER                                                                       CON_ID
-------------------- ---------- ---------------------------------------------------------------------------- ------
IBMPC/WIN_NT64-9.1.0 12.2.0.1.0 Oracle Database 12c Enterprise Edition Release 12.2.0.1.0 - 64bit Production      0

2.测试:
SCOTT@test01p> create table t as select rownum a1 , rownum a2 ,rownum a3 from dual connect by level<=100 ;
Table created.

create unique index i_t_a1 on t(a1);
create unique index i_t_a2 on t(a2);
create unique index i_t_a3 on t(a3);
--//分析略.

column STATEMENT_ID format a10
column OPTIONS format a20
explain plan set statement_id='a1' for select a1 from t where a1=100;
explain plan set statement_id='a2' for select a2 from t where a2=100;
explain plan set statement_id='a3' for select a3 from t where a3=100;

SCOTT@test01p> select STATEMENT_ID,OPERATION, OPTIONS, COST, CPU_COST, IO_COST, TIME from plan_table where options='UNIQUE SCAN';
STATEMENT_ OPERATION OPTIONS     COST CPU_COST IO_COST TIME
---------- --------- ----------- ---- -------- ------- ----
a1         INDEX     UNIQUE SCAN    0     1050       0    1
a2         INDEX     UNIQUE SCAN    0     1050       0    1
a3         INDEX     UNIQUE SCAN    0     1050       0    1
--//通过唯一索引访问cpu cost=1050.这里面包含行成本150,比较50。
--//通过hack看看变化.

SCOTT@test01p> select BLEVEL,LEAF_BLOCKS from user_indexes where index_name = 'I_T_A3';
BLEVEL LEAF_BLOCKS
------ -----------
     0           1

SCOTT@test01p> exec dbms_stats.set_index_stats(ownname=> NULL,indname=>'I_T_A3',indlevel=> 1000);
PL/SQL procedure successfully completed.

SCOTT@test01p> select BLEVEL,LEAF_BLOCKS from user_indexes where index_name = 'I_T_A3';
    BLEVEL LEAF_BLOCKS
---------- -----------
       255           1

--//注意:我修改indlevel=> 1000,实际上最大仅仅255.也就是最大blevel=255.
--//注:我记忆blevel最大64.如果hack blevel最好不要超过6X.不然在11g下会直接导致使用该索引的sql语句挂起!!切记!!
SCOTT@test01p> exec dbms_stats.set_index_stats(ownname=> NULL,indname=>'I_T_A3',indlevel=> 1000);
PL/SQL procedure successfully completed.

SCOTT@test01p> alter system flush shared_pool;
System altered.

column STATEMENT_ID format a10
column OPTIONS format a20

SCOTT@test01p> explain plan set statement_id='x3' for select /*+ index(t) */ a3 from t where a3=100;
Explained.

SCOTT@test01p> select STATEMENT_ID,OPERATION, OPTIONS, COST, CPU_COST, IO_COST, TIME from plan_table where STATEMENT_ID='x3';
STATEMENT_ OPERATION            OPTIONS                    COST   CPU_COST    IO_COST       TIME
---------- -------------------- -------------------- ---------- ---------- ---------- ----------
x3         SELECT STATEMENT                                   2    1817017          2          1
x3         INDEX                UNIQUE SCAN                 255    1817017        255          1
--//访问索引根节点,叶子节点占255块.
7121.44*255 = 1815967.20
1817017- 1815967.20 = 1049.80

--//修改blevel=254看看.
SCOTT@test01p> exec dbms_stats.set_index_stats(ownname=> NULL,indname=>'I_T_A3',indlevel=> 1000);
PL/SQL procedure successfully completed.

SCOTT@test01p> alter system flush shared_pool;
System altered.

SCOTT@test01p> explain plan set statement_id='x3' for select /*+ index(t) */ a3 from t where a3=100;
Explained.

SCOTT@test01p> select STATEMENT_ID,OPERATION, OPTIONS, COST, CPU_COST, IO_COST, TIME from plan_table where STATEMENT_ID='x3';
STATEMENT_ OPERATION            OPTIONS                    COST   CPU_COST    IO_COST       TIME
---------- -------------------- -------------------- ---------- ---------- ---------- ----------
x3         SELECT STATEMENT                                   2    1809896          2          1
x3         INDEX                UNIQUE SCAN                 254    1809896        254          1
--//访问索引根节点,叶子节点占255块.
7121.44*254 = 1808845.76
1809896 - 1808845.76 = 1050.24
7121.44*254+1050 = 1809895.76
--//无法通过HACK blevel测试.估计就是1050.
--//这样扣除行成本150,比较成本50. UNIQUE SCAN block 成本在=850.

5.看看索引范围的情况呢?
--//重新分析表T!!

column STATEMENT_ID format a10
column OPTIONS format a10
explain plan set statement_id='x100' for select /*+ index(t) */ 1 from t where a3>=100;
explain plan set statement_id='x050' for select /*+ index(t) */ 1 from t where a3>=050;

SCOTT@test01p> select STATEMENT_ID,OPERATION, OPTIONS, COST, CPU_COST, IO_COST, TIME from plan_table ;
STATEMENT_ OPERATION            OPTIONS                    COST   CPU_COST    IO_COST       TIME
---------- -------------------- -------------------- ---------- ---------- ---------- ----------
x100       SELECT STATEMENT                                   1       7321          1          1
x100       INDEX                RANGE SCAN                    1       7321          1          1
x050       SELECT STATEMENT                                   1      17521          1          1
x050       INDEX                RANGE SCAN                    1      17521          1          1

--//看看STATEMENT_ID=050的情况.
SCOTT@test01p> select BLEVEL,LEAF_BLOCKS from user_indexes where index_name = 'I_T_A3';
BLEVEL LEAF_BLOCKS
------ -----------
     0           1
--//Blevel=0 , LEAF_BLOCKS=1
--//块1块 7121.44 行1行 150, 比较 1次 50
--//索引选择率 = (100-50)/99+1/100 = 0.51505050505050505050,也就是card=52.
--//访问块  0.5150*1 = .5150 = 1 ,块成本= 1*7121.44= 7121
--//(行成本+比较成本)*card = 200*52 = 10400
--//10400+7121.44 = 17521.44

--//仅仅大致确定UNIQUE SCAN 块成本是1050.

[20190823]关于CPU成本计算3.txt的更多相关文章

  1. [20190823]关于CPU成本计算2.txt

    [20190823]关于CPU成本计算2.txt --//前几天探究CPU cost时遇到的问题,获取行成本时我的测试查询结果出现跳跃,不知道为什么,感觉有点奇怪,分析看看.--//ITPUB原始链接 ...

  2. [20190821]关于CPU成本计算.txt

    [20190821]关于CPU成本计算.txt --//有人问链接http://blog.itpub.net/267265/viewspace-2653964/中CPU成本如何计算的,实际上一般在优化 ...

  3. Trusted Execution Technology (TXT) --- 基本原理篇

    版权声明:本文为博主原创文章,未经博主允许不得转载. http://www.cnblogs.com/tsec/p/8409600.html 1. Intel TXT 介绍 TXT是Trusted Ex ...

  4. shell脚本监控系统负载、CPU和内存使用情况

    hostname >>/home/vmuser/xunjian/xj.logdf -lh >>/home/vmuser/xunjian/xj.logtop -b -n 1 | ...

  5. Linux CPU Hotplug CPU热插拔

    http://blog.chinaunix.net/uid-15007890-id-106930.html   CPU hotplug Support in Linux(tm) Kernel Linu ...

  6. centos 查看脚本

    centos 查看脚本 #!/bin/bash date >>info.txt echo "本机centos版本为" >>info.txt cat /etc ...

  7. Oracle的优化器介绍

    Oracle优化器介绍 本文讲述了Oracle优化器的概念.工作原理和使用方法,兼顾了Oracle8i.9i以及最新的10g三个版本.理解本文将有助于您更好的更有效的进行SQL优化工作. RBO优化器 ...

  8. Oracle优化器介绍

    Oracle优化器介绍 本文讲述了Oracle优化器的概念.工作原理和使用方法,兼顾了Oracle8i.9i以及最新的10g三个版本.理解本文将有助于您更好的更有效的进行SQL优化工作. RBO优化器 ...

  9. Linux 性能搜集【linux_reports-cpu/memory/disks/network】

    为方便问题发生后,问题原因的分析排查,我们可以在服务器中事先部署如下脚本,方便故障发生后,问题原因的分析排查 脚本部署方法: 1.将脚本[linux_reports.sh]上传到服务器 2.登陆虚拟机 ...

随机推荐

  1. Python3 进程、线程和协程

    Infi-chu: http://www.cnblogs.com/Infi-chu/ 进程.线程和协程的对比 1.定义对比 进程:是系统进行资源分配的基本单位,每启动一个进程,操作系统都需要为其分配运 ...

  2. 前端JS实现一键导入excel表格

    前面的文章中已经讲过关于js表格的导出,此文章主要说到的是excel文件如何导入到网页中,并在网页端显示. 代码部分: <!DOCTYPE html> <html> <h ...

  3. 【分享】nginx负载均衡全套视频教程

    1.课件 百度网盘链接:https://pan.baidu.com/s/1On2oONVZmPwI9yIDekgRiA        提取码:c4fw 2.教程列表 3.教程下载 3.1.直接在线学习 ...

  4. HTTPS混合内容解析

    什么是HTTPS混合内容 我们可能会有这样的经验,当我们通过HTTPS访问一个网站的时候,突然有提示:“本页面包含有不安全的内容”.这个时候会询问是否显示“不安全的内容”,这个时候,就是遇到了有混合内 ...

  5. java8-9-Stream 的中间操作

        Stream 的中间操作   filter 过滤 排除元素 filter(T -> boolean) 保留 boolean 为 true 的元素

  6. go语言设计模式之memento

    memento.go package memento import ( "fmt" ) type State struct { Description string } type ...

  7. [Linux]终端设备关系

    1.概述 tty中基本上可以划分为console(/dev/console).虚拟终端(/dev/tty0~n)和伪终端(/dev/pts/0~n). 它们之间存在一定的关系. 为了说明这段关系,先要 ...

  8. MongoDB学习笔记(三、MongoDB聚合与更新)

    目录: 聚合 更新 更新选择器 ObjectId 更新操作的原子性 聚合: 聚合语法:db.collectionName.aggregate(aggregate_operation) 聚合操作其实就是 ...

  9. AcWing 30. 正则表达式匹配 (剑指OFFER leetcode 10)

    题目描述请实现一个函数用来匹配包括’.’和’*’的正则表达式. 模式中的字符’.’表示任意一个字符,而’*’表示它前面的字符可以出现任意次(含0次). 在本题中,匹配是指字符串的所有字符匹配整个模式. ...

  10. SP2713 GSS4 - Can you answer these queries IV 分块

    问题描述 LG-SP2713 题解 分块,区间开根. 如果一块的最大值是 \(1\) ,那么这个块就不用开根了. 如果最大值不是 \(1\) ,直接暴力开就好了. \(\mathrm{Code}\) ...