========  测试表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优化_隐式-显示转换的更多相关文章

  1. Java数据类型的转换:隐式(自动)转换与强制转换

    原文链接:http://java.chinaitlab.com/base/725590.html 一些初学JAVA的朋友可能会遇到JAVA的数据类型之间转换的苦恼,例如,整数和float,double ...

  2. 你不知道的JavaScript--Item3 隐式强制转换

    JavaScript的数据类型分为六种,分别为null,undefined,boolean,string,number,object. object是引用类型,其它的五种是基本类型或者是原始类型.我们 ...

  3. 深入js系列-类型(隐式强制转换)

    隐式强制转换 在其可控的情况下,减少冗余,让代码更简洁,很多地方都进行了隐式转换,比如常见的三目表达式.if().for().while.逻辑运算符 || &&,适当通过语言机制,抽象 ...

  4. 显示(explicit )与隐式(implicit)转换操作符

    class Program { static void Main(string[] args) { /* * 不管是显示还是隐式转换,一种类型都只能出现一次 */ Console.WriteLine( ...

  5. 2019.03.20 读书笔记 as is 以及重写隐式/显示

    强转.as is 的用法 强制转换类型有两种:子类转基类,重写隐式(implicit )\显示(explicit) 转换操作符 class myclass { private int value; p ...

  6. VC 静态库与动态库(三)动态库创建与使用_隐式链接

    动态库分为二种,一种隐式链接,另一种显示调用.不论哪种动态库,本质都是运行时动态加载 隐式链接:程序运行时,由编译系统自动加载动态库,然后根据程序的引入表进行重定位,当程序退出时自动卸载动态库 显示调 ...

  7. ahjesus自定义隐式转换和显示转换

    implicit    关键字用于声明隐式的用户定义类型转换运算符. 如果可以确保转换过程不会造成数据丢失,则可使用该关键字在用户定义类型和其他类型之间进行隐式转换. 参考戳此 explicit    ...

  8. DB性能-隐式转换

    1        什么是隐式转换 当源数据的类型和目标数据的类型不同的时候,如果没有转换函数,就会发生隐式转换,也称自动转换.当然, 有些情况下有些类型是不可以发生转换的,比如说从DATE类型转换到N ...

  9. ORACLE数据库中执行计划出现INTERNAL_FUNCTION一定是隐式转换吗?

    ORACLE数据库中,我们会使用一些SQL语句找出存在隐式转换的问题SQL,其中网上流传的一个SQL语句如下,查询V$SQL_PLAN的字段FILTER_PREDICATES中是否存在INTERNAL ...

随机推荐

  1. 基于react hooks,antd4 配置生成表单并自动排列

    react后台项目,大多都是表单处理,比如下列4种常见1*n布局 (如果手工编码,大量的Row,Col, Form.Item的嵌套,排列,如果加上联动处理,代码将十分臃肿,不易维护) 一行一列 一行两 ...

  2. springboot项目部署(war包)

    将springboot项目打包成war,并且部署到tomcat.比较麻烦,自己踩的坑也比较多.算了一下,找bug的时间,有两天熬到凌晨2点. 修改pom.xml使得打包成war <groupId ...

  3. WireShark之抓telnet密码

    背景环境: 涉及到telnet和ssh知识的时候,必须要提的是telnet传输是明文的不安全的,传输的密码都会泄露,有兴趣来做个试验. 一:工具 ·①Windows 7 PC机:②GNS3:③Wire ...

  4. 测开之Python自动化全栈工程师+性能专项(送思维导图)

    测开之Python自动化全栈工程师+性能专项 功能测试基础 接口测试基础接口的通信原理与本质cookie.session.token详解接口测试的意义与测试方法接口测试用例的设计 app测试 app流 ...

  5. 是时候学习Linux了

    前言: Linux是一个开源.免费的操作系统.其稳定性.安全性.处理多并发已经得到业界的认可,目前很多企业级的项目都会部署到Linux/unix系统上.如果你还不太了解Linux,希望本篇文章能够带你 ...

  6. 发布声明$\beta$

    一.新功能 \(\beta\)阶段集中开发了3大核心功能:支持模块的嵌套.模型市场.模型推理,这三项基本上都是从零开始.徒手开发的功能,没有轮子可以参照,因此也不具有可以对比的先前版本. 除此之外,开 ...

  7. 不同规模的企业对CRM的需求是否相同?

    CRM客户管理系统在我们的认知中往往是中大型企业的选择.如今,越来越多中小规模企业开始使用CRM系统.CRM的功能随着发展变得越来越实用,可以满足不同行业不同业务规模的企业的需求.同时,CRM功能类型 ...

  8. 【大白话 mysql】mysql 事务与日志原理

    在后端面试中,mysql是比不可少的一环,其中对事务和日志的考察更是"重灾区", 大部分同学可能都知道mysql通过redolog.binlog和undolog保证了sql的事务性 ...

  9. 最全的cURL命令使用

    cURL是什么 curl是Linux命令行工具,可以使用任何可支持的协议(如HTTP.FTP.IMAP.POP3.SCP.SFTP.SMTP.TFTP.TELNET.LDAP或FILE)在服务器之间传 ...

  10. Mysql数据库-多实例主从复制-主从故障详解

    一.mysql结构 1.实例 1.什么是单实例 一个进程 + 多个线程 + 一个预分配的内存空间 2.多实例 多个进程 + 多个线程 + 多个预分配的内存空间 ](http://shelldon.51 ...