========  测试表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. hdu4291 暴力循环节+矩阵快速幂

    题意:       给你一个关系式,x[n] = 3*x[n-1] + x[n-2],求x(x(x[n]))%1000000007. 思路:       做这个题目要明确一点,就是对于取余操作大多数时 ...

  2. DVWA之DOM XSS(DOM型跨站脚本攻击)

    目录 Low Medium High Impossible Low 源代码: <?php # No protections, anything goes ?> 从源代码可以看出,这里low ...

  3. CMS Joomla SQL注入漏洞练习(CVE-2017-8917 )

    0x01 原理 1.Joomla是内容管理的网站程序,也就是CMS.漏洞原理是com_fields组件,对请求数据过滤不严谨,从而导致sql注入.这个就是有问题的代码,可以看出sql根本没有过滤,通过 ...

  4. Sqlmap的使用详解

    目录 Sqlmap Sqlmap的简单用法 探测指定URL是否存在SQL注入漏洞 查看数据库的所有用户 查看数据库所有用户名的密码 查看数据库当前用户 判断当前用户是否有管理权限 列出数据库管理员角色 ...

  5. (2) arm 指令条件码

    条件码助记符 标志 含义 EQ Z=1 相等 NE Z=0 不相等 CS/HS C=1 无符号数大于或等于 CC/LO C=0 无符号数小于 MI N=1 负数 PL N=0 正数或0 VS V=1 ...

  6. 求曲线y=lnx在区间(2,6)内的一条切线,使得该切线与直线x=2,x=6及曲线y=lnx所围成的图形的面积最小。

    求曲线y=lnx在区间(2,6)内的一条切线,使得该切线与直线x=2,x=6及曲线y=lnx所围成的图形的面积最小. 1.先画图. 2.设切点为(a,lna) (2<a<6) 3.切线方程 ...

  7. 【小技巧】Eclipse 中创建Maven项目后没有WEB-INF文件夹以及web.xml文件

    懒得截图了,一张图配下面步骤搞定. 1.右键项目,选择propertities后选择图中①(被遮住了): 2.先不②勾选去掉,点击Apply:然后在把②处勾选上.此时④位置会出现东东,点击蓝色超链接. ...

  8. 月薪6K和月薪2W的测试,有什么区别?

    之前,我收到了一位朋友的好消息,说自己拿到了接近月薪 20k 的 offer.   说实话,软件测试岗位前期门槛低,但是想要拿到高薪真没那么简单.工作 2-3 年薪资还在原地打转的同学,都大有人在. ...

  9. Pytorch多卡训练

    前一篇博客利用Pytorch手动实现了LeNet-5,因为在训练的时候,机器上的两张卡只用到了一张,所以就想怎么同时利用起两张显卡来训练我们的网络,当然LeNet这种层数比较低而且用到的数据集比较少的 ...

  10. ]# dmesg | grep ATAcentos下查看网卡,主板,CPU,显卡,硬盘型号等硬件信息

    centos下查看网卡,主板,CPU,显卡,硬盘型号等硬件信息 osc_4o5tc4xq 2019/10/11 15:03 阅读数 253 centos下查看网卡,主板,CPU,显卡,硬盘型号等硬件信 ...