【DB笔试面试617】在Oracle中,和“表达式和条件评估”相关的查询转换有哪些?...

版权声明:本文为博主原创文章,遵循 CC 4.0 by-sa 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/lihuarongaini/article/details/99382382

640?wx_fmt=gif

题目部分

在Oracle中,和“表达式和条件评估”相关的查询转换有哪些?


     
答案部分



(一)逻辑转换

 1LHR@orclasm > SELECT   /*+FULL(A) FULL(B)*/  * FROM SCOTT.EMP A,SCOTT.DEPT B WHERE   A.DEPTNO=B.DEPTNO  AND B.DEPTNO=20; 2 3Execution Plan 4---------------------------------------------------------- 5Plan hash value: 4192419542 6 7--------------------------------------------------------------------------- 8| Id  | Operation          | Name | Rows  | Bytes | Cost (%CPU)| Time     | 9---------------------------------------------------------------------------10|   0 | SELECT STATEMENT   |      |     4 |   468 |     5   (0)| 00:00:01 |11|   1 |  NESTED LOOPS      |      |     4 |   468 |     5   (0)| 00:00:01 |12|*  2 |   TABLE ACCESS FULL| DEPT |     1 |    30 |     2   (0)| 00:00:01 |13|*  3 |   TABLE ACCESS FULL| EMP  |     5 |   435 |     3   (0)| 00:00:01 |14---------------------------------------------------------------------------1516Predicate Information (identified by operation id):17---------------------------------------------------1819   2 - filter("B"."DEPTNO"=20)20   3 - filter("A"."DEPTNO"=20)SELECT   /*+FULL(A) FULL(B)*/  * FROM SCOTT.EMP A,SCOTT.DEPT B WHERE   A.DEPTNO=B.DEPTNO  AND B.DEPTNO=20;
2
3Execution Plan
4----------------------------------------------------------
5Plan hash value: 4192419542
6
7---------------------------------------------------------------------------
8| Id  | Operation          | Name | Rows  | Bytes | Cost (%CPU)| Time     |
9---------------------------------------------------------------------------
10|   0 | SELECT STATEMENT   |      |     4 |   468 |     5   (0)| 00:00:01 |
11|   1 |  NESTED LOOPS      |      |     4 |   468 |     5   (0)| 00:00:01 |
12|*  2 |   TABLE ACCESS FULL| DEPT |     1 |    30 |     2   (0)| 00:00:01 |
13|*  3 |   TABLE ACCESS FULL| EMP  |     5 |   435 |     3   (0)| 00:00:01 |
14---------------------------------------------------------------------------
15
16Predicate Information (identified by operation id):
17---------------------------------------------------
18
19   2 - filter("B"."DEPTNO"=20)
20   3 - filter("A"."DEPTNO"=20)


(二)常量转换

 1LHR@orclasm > SELECT  * FROM SCOTT.EMP A WHERE a.sal>=100+50; 2Execution Plan 3---------------------------------------------------------- 4Plan hash value: 3956160932 5 6-------------------------------------------------------------------------- 7| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     | 8-------------------------------------------------------------------------- 9|   0 | SELECT STATEMENT  |      |    14 |  1218 |     3   (0)| 00:00:01 |10|*  1 |  TABLE ACCESS FULL| EMP  |    14 |  1218 |     3   (0)| 00:00:01 |11--------------------------------------------------------------------------1213Predicate Information (identified by operation id):14---------------------------------------------------1516   1 - filter("A"."SAL">=150)SELECT  * FROM SCOTT.EMP A WHERE a.sal>=100+50;
2Execution Plan
3----------------------------------------------------------
4Plan hash value: 3956160932
5
6--------------------------------------------------------------------------
7| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
8--------------------------------------------------------------------------
9|   0 | SELECT STATEMENT  |      |    14 |  1218 |     3   (0)| 00:00:01 |
10|*  1 |  TABLE ACCESS FULL| EMP  |    14 |  1218 |     3   (0)| 00:00:01 |
11--------------------------------------------------------------------------
12
13Predicate Information (identified by operation id):
14---------------------------------------------------
15
16   1 - filter("A"."SAL">=150)


(三)LIKE转换

 1LHR@orclasm > SELECT  * FROM SCOTT.EMP A WHERE A.ENAME LIKE 'lhr' ; 2-------------------------------------------------------------------------- 3| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     | 4-------------------------------------------------------------------------- 5|   0 | SELECT STATEMENT  |      |     1 |    87 |     3   (0)| 00:00:01 | 6|*  1 |  TABLE ACCESS FULL| EMP  |     1 |    87 |     3   (0)| 00:00:01 | 7-------------------------------------------------------------------------- 8 9Predicate Information (identified by operation id):10---------------------------------------------------1112   1 - filter("A"."ENAME"='lhr')SELECT  * FROM SCOTT.EMP A WHERE A.ENAME LIKE 'lhr' ;
2--------------------------------------------------------------------------
3| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
4--------------------------------------------------------------------------
5|   0 | SELECT STATEMENT  |      |     1 |    87 |     3   (0)| 00:00:01 |
6|*  1 |  TABLE ACCESS FULL| EMP  |     1 |    87 |     3   (0)| 00:00:01 |
7--------------------------------------------------------------------------
8
9Predicate Information (identified by operation id):
10---------------------------------------------------
11
12   1 - filter("A"."ENAME"='lhr')


(四)IN转换

 1LHR@orclasm > SELECT  * FROM SCOTT.EMP A WHERE A.ENAME IN ('lhr','DBA') ; 2-------------------------------------------------------------------------- 3| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     | 4-------------------------------------------------------------------------- 5|   0 | SELECT STATEMENT  |      |     1 |    87 |     3   (0)| 00:00:01 | 6|*  1 |  TABLE ACCESS FULL| EMP  |     1 |    87 |     3   (0)| 00:00:01 | 7-------------------------------------------------------------------------- 8 9Predicate Information (identified by operation id):10---------------------------------------------------1112   1 - filter("A"."ENAME"='DBA' OR "A"."ENAME"='lhr')SELECT  * FROM SCOTT.EMP A WHERE A.ENAME IN ('lhr','DBA') ;
2--------------------------------------------------------------------------
3| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
4--------------------------------------------------------------------------
5|   0 | SELECT STATEMENT  |      |     1 |    87 |     3   (0)| 00:00:01 |
6|*  1 |  TABLE ACCESS FULL| EMP  |     1 |    87 |     3   (0)| 00:00:01 |
7--------------------------------------------------------------------------
8
9Predicate Information (identified by operation id):
10---------------------------------------------------
11
12   1 - filter("A"."ENAME"='DBA' OR "A"."ENAME"='lhr')


(五)BETWEEN AND转换


 1LHR@orclasm > SELECT  * FROM SCOTT.EMP A WHERE A.EMPNO BETWEEN 1 AND 2; 2-------------------------------------------------------------------------------------- 3| Id  | Operation                   | Name   | Rows  | Bytes | Cost (%CPU)| Time     | 4-------------------------------------------------------------------------------------- 5|   0 | SELECT STATEMENT            |        |     1 |    87 |     1   (0)| 00:00:01 | 6|   1 |  TABLE ACCESS BY INDEX ROWID| EMP    |     1 |    87 |     1   (0)| 00:00:01 | 7|*  2 |   INDEX RANGE SCAN          | PK_EMP |     1 |       |     1   (0)| 00:00:01 | 8-------------------------------------------------------------------------------------- 910Predicate Information (identified by operation id):11---------------------------------------------------1213   2 - access("A"."EMPNO">=1 AND "A"."EMPNO"<=2)SELECT  * FROM SCOTT.EMP A WHERE A.EMPNO BETWEEN 1 AND 2;
2--------------------------------------------------------------------------------------
3| Id  | Operation                   | Name   | Rows  | Bytes | Cost (%CPU)| Time     |
4--------------------------------------------------------------------------------------
5|   0 | SELECT STATEMENT            |        |     1 |    87 |     1   (0)| 00:00:01 |
6|   1 |  TABLE ACCESS BY INDEX ROWID| EMP    |     1 |    87 |     1   (0)| 00:00:01 |
7|*  2 |   INDEX RANGE SCAN          | PK_EMP |     1 |       |     1   (0)| 00:00:01 |
8--------------------------------------------------------------------------------------
9
10Predicate Information (identified by operation id):
11---------------------------------------------------
12
13   2 - access("A"."EMPNO">=1 AND "A"."EMPNO"<=2)


本文选自《Oracle程序员面试笔试宝典》,作者:李华荣。



640?wx_fmt=gif

---------------优质麦课------------

640?wx_fmt=png

 详细内容可以添加麦老师微信或QQ私聊。


640?wx_fmt=gif


About Me:小麦苗

 本文作者:小麦苗,只专注于数据库的技术,更注重技术的运用

● 作者博客地址:http://blog.itpub.net/26736162/abstract/1/

 本系列题目来源于作者的学习笔记,部分整理自网络,若有侵权或不当之处还请谅解

 版权所有,欢迎分享本文,转载请保留出处

 QQ:646634621  QQ群:618766405

 提供OCP、OCM和高可用部分最实用的技能培训

● 题目解答若有不当之处,还望各位朋友批评指正,共同进步

640?wx_fmt=gifDBA宝典

长按下图识别二维码或微信扫描下图二维码来关注小麦苗的微信公众号:xiaomaimiaolhr,学习最实用的数据库技术。

640?wx_fmt=gif

640?wx_fmt=gif

640?wx_fmt=png喜欢就点击“好看”吧



展开阅读全文

面试相关-技术问题(转)

11-28

1. C中static有什么作用?rn(1)隐藏。 当我们同时编译多个文件时,所有未加static前缀的全局变量和函数都具有全局可见性,故使用static在不同的文件中定义同名函数和同名变量,而不必担心命名冲突。rn(2)static的第二个作用是保持变量内容的持久。存储在静态数据区的变量会在程序刚开始运行时就完成初始化,也是唯一的一次初始化。共有两种变量存储在静态存储区:全局变量和static变量。rn(3)static的第三个作用是默认初始化为0。其实全局变量也具备这一属性,因为全局变量也存储在静态数据区。在静态数据区,内存中所有的字节默认值都是0x00,某些时候这一特点可以减少程序员的工作量。rn2.C++中const有什么用?rn不要一听到const就说是常量,这样给考官一种在和一个外行交谈的感觉。应该说const修饰的内容不可改变就行了, 定义常量只是一种使用方式而已,还有const数据成员,const参数, const返回值, const成员函数等, 被const修饰的东西都受到强制保护,可以预防意外的变动,能提高程序的健壮性。rnrn3. C与C++各自是如何定义常量的?有什么不同?rnC中是使用宏#define定义, C++使用更好的const来定义。rn区别:1)const是有数据类型的常量,而宏常量没有, 编译器可以对前者进行静态类型安全检查,对后者仅是字符替换,没有类型安全检查,而且在字符替换时可能会产生意料不到的错误(边际效应)。2)有些编译器可以对const常量进行调试, 不能对宏调试。rn4. 既然C++中有更好的const为什么还要使用宏?rnconst无法代替宏作为卫哨来防止文件的重复包含。rn5. C++中引用和指针的区别?rn引用是对象的别名, 操作引用就是操作这个对象, 必须在创建的同时有效得初始化(引用一个有效的对象, 不可为NULL), 初始化完毕就再也不可改变, 引用具有指针的效率, 又具有变量使用的方便性和直观性, 在语言层面上引用和对象的用法一样, 在二进制层面上引用一般都是通过指针来实现的, 只是编译器帮我们完成了转换. 之所以使用引用是为了用适当的工具做恰如其分的事, 体现了最小特权原则.rn6. 说一说C与C++的内存分配方式?rn1)从静态存储区域分配。内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在,如全局变量,static变量。rn2)在栈上创建。在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中,效率很高,但是分配的内存容量有限。3)从堆上分配(动态内存分配)程序在运行的时候用malloc或new申请任意多少的内存,程序员负责在何时用free或delete释放内存。动态内存的生存期自己决定,使用非常灵活。rn7. new/delete 与 malloc()/free() 的区别?rnmalloc() 与 free() 是C语言的标准库函数, new/delete 是C++的运算符, 他们都可以用来申请和释放内存, malloc()和free()不在编译器控制权限之内, 不能把构造函数和析构函数的任务强加给他们.rn8. #include和#include“a.h” 有什么区别?rn答:对于#include ,编译器从标准库路径开始搜索 a.h对于#include “a.h” ,编译器从用户的工作路径开始搜索 a.hrn9. 在C++ 程序中调用被 C编译器编译后的函数,为什么要加 extern “C”?rnC++语言支持函数重载,C语言不支持函数重载。函数被C++编译后在库中的名字与C语言的不同。假设某个函数的原型为: void foo(int x, int y);该函数被C编译器编译后在库中的名字为_foo,而C++编译器则会产生像_foo_int_int之类的名字。C++提供了C连接交换指定符号extern“C”来解决名字匹配问题。rn10. C++中的什么是多态性? 是如何实现的?rn多态性是面向对象程序设计语言继数据抽象和继承之后的第三个基本特征。它是在运行时出现的多态性通过派生类和虚函数实现。基类和派生类中使用同样的函数名, 完成不同的操作具体实现相隔离的另一类接口,即把“ w h a t”从“h o w”分离开来。多态性提高了代码的组织性和可读性,虚函数则根据类型的不同来进行不同的隔离。rn11. 什么是动态特性?rn在绝大多数情况下, 程序的功能是在编译的时候就确定下来的, 我们称之为静态特性. 反之, 如果程序的功能是在运行时刻才能确定下来的, 则称之为动态特性。C++中, 虚函数, 抽象基类, 动态绑定和多态构成了出色的动态特性。rn12.什么是封装?C++中是如何实现的?rn封装来源于信息隐藏的设计理念, 是通过特性和行为的组合来创建新数据类型让接口与具体实现相隔离。C++中是通过类来实现的, 为了尽量避免某个模块的行为干扰同一系统中的其它模块,应该让模块仅仅公开必须让外界知道的接口.rnrnrn13. 什么是RTTI?rnRTTI事指运行时类型识别(Run-time type identification)在只有一个指向基类的指针或引用时确定一个对象的准确类型。rn14. 什么是拷贝构造函数?rn它是单个参数的构造函数,其参数是与它同属一类的对象的(常)引用;类定义中,如果未提供自己的拷贝构造函数,C++提供一个默认拷贝构造函数,该默认拷贝构造函数完成一个成员到一个成员的拷贝rn15. 什么是深浅拷贝?rn浅拷贝是创建了一个对象用一个现成的对象初始化它的时候只是复制了成员(简单赋值)而没有拷贝分配给成员的资源(如给其指针变量成员分配了动态内存); 深拷贝是当一个对象创建时,如果分配了资源,就需要定义自己的拷贝构造函数,使之不但拷贝成员也拷贝分配给它的资源.rn16.面向对象程序设计的优点?rn开发时间短, 效率高, 可靠性高。面向对象编程的编码具有高可重用性,可以在应用程序中大量采用成熟的类库(如STL),从而虽短了开发时间,软件易于维护和升级。 论坛

没有更多推荐了,返回首页