sql优化_隐式-显示转换
======== 测试表1信息 =======
SQL> select count(*) from tb_test;
COUNT(*)
----------
3000000
SQL> select count(*) from tb_test where name='1' or name='0';
COUNT(*)
----------
3000000
SQL> desc tb_test
Name Null? Type
-------------------------- -------- -----------------
ID NUMBER
INC_DATETIME VARCHAR2(19)
RANDOM_ID NUMBER
RANDOM_STRING VARCHAR2(4000)
NAME VARCHAR2(20)
=========== 索引信息 ===========
OWNER TABLE_NAME INDEX_NAME INDEX_TYPE
------- ------------ ------------- ------------
TEST TB_TEST IDX_INC NORMAL
TEST TB_TEST NAME_IX NORMAL
TEST TB_TEST ID_IX NORMAL
====== 测试表2信息 ==========
SQL> desc tb_test1
Name Null? Type
----------------------------------------------------- -------- ------------------------------------
ID NUMBER
INC_DATETIME VARCHAR2(19)
RANDOM_ID NUMBER
RANDOM_STRING VARCHAR2(4000)
SQL> select count(*) from tb_test1
COUNT(*)
----------
110
============ 使用隐式转换 ============
使用隐式转换未使用索引,全表扫描,IO开销大,执行速度慢。
explain plan for select id from tb_test where
id not in ( select id from tb_test1 ) and
RANDOM_STRING=0 and name=1;
SQL> select * from table(dbms_xplan.display);
PLAN_TABLE_OUTPUT
---------------------------------------------------------------------------------
Plan hash value: 2850541703
----------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
-----------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | 26 | 2762 (1)| 00:00:34 |
|* 1 | HASH JOIN ANTI NA | | 1 | 26 | 2762 (1)| 00:00:34 |
|* 2 | TABLE ACCESS FULL| TB_TEST | 1 | 13 | 2758 (1)| 00:00:34 |
| 3 | TABLE ACCESS FULL| TB_TEST1 | 110 | 1430 | 4 (0)| 00:00:01 |
-------------------------------------------------------------------------------
=============== 使用显示转换 ==================
使用显示转换,索引扫描,IO开销小,执行快。
SQL> explain plan for select id from tb_test where
2 id not in ( select id from tb_test1 ) and
3 RANDOM_STRING='0' and name='1';
Explained.
SQL> select * from table(dbms_xplan.display);
PLAN_TABLE_OUTPUT
-----------------------------------------------------------------------------------------
Plan hash value: 3484870784
-----------------------------------------------------------------------------------------
| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |
---------------------------------------------------------------------------------------------------
| 0 | SELECT STATEMENT | | 1 | 26 | 8 (0)| 00:00:01 |
|* 1 | HASH JOIN ANTI NA | | 1 | 26 | 8 (0)| 00:00:01 |
|* 2 | TABLE ACCESS BY INDEX ROWID| TB_TEST | 1 | 13 | 4 (0)| 00:00:01 |
|* 3 | INDEX RANGE SCAN | NAME_IX | 6 | | 3 (0)| 00:00:01 |
| 4 | TABLE ACCESS FULL | TB_TEST1 | 110 | 1430 | 4 (0)| 00:00:01 |
--------------------------------------------------------------------------------------------------
总结:1、隐式转换发生在字段列上时将使索引失效
2、RANDOM_STRING和name虽含有大量重复值,使用索引的效率仍然很高。
sql优化_隐式-显示转换的更多相关文章
- Java数据类型的转换:隐式(自动)转换与强制转换
原文链接:http://java.chinaitlab.com/base/725590.html 一些初学JAVA的朋友可能会遇到JAVA的数据类型之间转换的苦恼,例如,整数和float,double ...
- 你不知道的JavaScript--Item3 隐式强制转换
JavaScript的数据类型分为六种,分别为null,undefined,boolean,string,number,object. object是引用类型,其它的五种是基本类型或者是原始类型.我们 ...
- 深入js系列-类型(隐式强制转换)
隐式强制转换 在其可控的情况下,减少冗余,让代码更简洁,很多地方都进行了隐式转换,比如常见的三目表达式.if().for().while.逻辑运算符 || &&,适当通过语言机制,抽象 ...
- 显示(explicit )与隐式(implicit)转换操作符
class Program { static void Main(string[] args) { /* * 不管是显示还是隐式转换,一种类型都只能出现一次 */ Console.WriteLine( ...
- 2019.03.20 读书笔记 as is 以及重写隐式/显示
强转.as is 的用法 强制转换类型有两种:子类转基类,重写隐式(implicit )\显示(explicit) 转换操作符 class myclass { private int value; p ...
- VC 静态库与动态库(三)动态库创建与使用_隐式链接
动态库分为二种,一种隐式链接,另一种显示调用.不论哪种动态库,本质都是运行时动态加载 隐式链接:程序运行时,由编译系统自动加载动态库,然后根据程序的引入表进行重定位,当程序退出时自动卸载动态库 显示调 ...
- ahjesus自定义隐式转换和显示转换
implicit 关键字用于声明隐式的用户定义类型转换运算符. 如果可以确保转换过程不会造成数据丢失,则可使用该关键字在用户定义类型和其他类型之间进行隐式转换. 参考戳此 explicit ...
- DB性能-隐式转换
1 什么是隐式转换 当源数据的类型和目标数据的类型不同的时候,如果没有转换函数,就会发生隐式转换,也称自动转换.当然, 有些情况下有些类型是不可以发生转换的,比如说从DATE类型转换到N ...
- ORACLE数据库中执行计划出现INTERNAL_FUNCTION一定是隐式转换吗?
ORACLE数据库中,我们会使用一些SQL语句找出存在隐式转换的问题SQL,其中网上流传的一个SQL语句如下,查询V$SQL_PLAN的字段FILTER_PREDICATES中是否存在INTERNAL ...
随机推荐
- php笔记之魔术方法、魔法常量和超全局变量
一.魔术方法(13个)1.__construct()实例化对象时被调用, 当__construct和以类名为函数名的函数同时存在时,__construct将被调用,另一个不被调用.2.__destru ...
- 【小技巧】修改eclipse中Java注释中的作者日期等信息
- spring源码解析之属性编辑器propertyEditor
异常信息造成此异常的原因bean配置文件调用代码特别说明:异常解决注册springt自带的属性编辑器 CustomDateEditor控制台输出属性编辑器是何时并如何被注册到spring容器中的?查看 ...
- 运行程序显示丢失“MSVCR100D.dll”
前言 写了一个Dll注入工具,结果发现程序在其他机器上会出现丢失"MSVCR100D.dll".这个dll是vs2010自带的动态链接库,如果在没安装vs2010运行库的电脑中使用 ...
- OOP第二章博客
OO第二次博客作业 (1)作业分析 三次作业在处理多线程的协同配合时都是使用将同步放在自己写的"线程安全类"(经测试有些许漏洞_,但是不影响结果就是了): 我个人倾向于把wait( ...
- 2.HTML案例二 头条页面
4 HTML案例-头条页面 4.1 案例效果 4.2 案例分析 4.2.1 div布局的进阶 想要将div布局成案例效果,首先需要对多个div进行区分,再分别设置每一个div自身的效果. 1)div的 ...
- .NetCore·集成Ocelot组件之完全解决方案
阅文时长 | 11.04分钟 字数统计 | 17672.8字符 主要内容 | 1.前言.环境说明.预备知识 2.Ocelot基本使用 3.Ocelot功能挖掘 4.Ocelot集成其他组件 5.避坑指 ...
- [转载]libvirt(virsh命令总结)
libvirt(virsh命令总结) virsh回车进入交互式界面: version pwd hostname 显示本节点主机名 nodeinfo 显示节点信息 list --all 显示所有云主机 ...
- echo -n -e "请输入重启间隔的时间(分钟):\t"
echo -n -e "请输入重启间隔的时间(分钟):\t"read interval##echo -n "Your choice is " # 加上 -n 可 ...
- mysql有关配置
mysql有关配置 mysql安装 mysql安装方式有三种 源代码:编译安装 二进制格式的程序包:展开至特定路径,并经过简单配置后即可使用 程序包管理器管理的程序包: rpm:有两种 OS Vend ...