oracle开发人员面试题.docx
- 文档编号:1981874
- 上传时间:2022-10-25
- 格式:DOCX
- 页数:26
- 大小:36.44KB
oracle开发人员面试题.docx
《oracle开发人员面试题.docx》由会员分享,可在线阅读,更多相关《oracle开发人员面试题.docx(26页珍藏版)》请在冰豆网上搜索。
oracle开发人员面试题
一、基础概念
1.列举几种表连接方式
Answer:
等连接(内连接)、非等连接、自连接、外连接(左、右、全)
Orhashjoin/mergejoin/nestloop(clusterjoin)/indexjoin?
?
ORACLE8i,9i表连接方法。
一般的相等连接:
select*froma,bwherea.id=b.id;这个就属于内连接。
对于外连接:
Oracle中可以使用“(+)”来表示,9i可以使用LEFT/RIGHT/FULLOUTERJOIN
LEFTOUTERJOIN:
左外关联
SELECTe.last_name,e.department_id,d.department_name
FROMemployeese
LEFTOUTERJOINdepartmentsd
ON(e.department_id=d.department_id);
等价于
SELECTe.last_name,e.department_id,d.department_name
FROMemployeese,departmentsd
WHEREe.department_id=d.department_id(+)
结果为:
所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录。
RIGHTOUTERJOIN:
右外关联
SELECTe.last_name,e.department_id,d.department_name
FROMemployeese
RIGHTOUTERJOINdepartmentsd
ON(e.department_id=d.department_id);
等价于
SELECTe.last_name,e.department_id,d.department_name
FROMemployeese,departmentsd
WHEREe.department_id(+)=d.department_id
结果为:
所有员工及对应部门的记录,包括没有任何员工的部门记录。
FULLOUTERJOIN:
全外关联
SELECTe.last_name,e.department_id,d.department_name
FROMemployeese
FULLOUTERJOINdepartmentsd
ON(e.department_id=d.department_id);
结果为:
所有员工及对应部门的记录,包括没有对应部门编号department_id的员工记录和没有任何员工的部门记录。
ORACLE8i是不直接支持完全外连接的语法,也就是说不能在左右两个表上同时加上(+),下面是在ORACLE8i可以参考的完全外连接语法
selectt1.id,t2.idfromtable1t1,tablet2wheret1.id=t2.id(+)
union
selectt1.id,t2.idfromtable1t1,tablet2wheret1.id(+)=t2.id
连接类型
定义图示例子
内连接只连接匹配的行selectA.c1,B.c2fromAjoinBonA.c3=B.c3;
左外连接包含左边表的全部行(不管右边的表中是否存在与它们匹配的行)以及右边表中全部匹配的行selectA.c1,B.c2fromAleftjoinBonA.c3=B.c3;
右外连接包含右边表的全部行(不管左边的表中是否存在与它们匹配的行)以及左边表中全部匹配的行selectA.c1,B.c2fromArightjoinBonA.c3=B.c3;
全外连接包含左、右两个表的全部行,不管在另一边的表中是否存在与它们匹配的行selectA.c1,B.c2fromAfulljoinBonA.c3=B.c3;
(theta)连接使用等值以外的条件来匹配左、右两个表中的行selectA.c1,B.c2fromAjoinBonA.c3!
=B.c3;
交叉连接生成笛卡尔积——它不使用任何匹配或者选取条件,而是直接将一个数据源中的每个行与另一个数据源的每个行一一匹配 selectA.c1,B.c2fromA,B;
2.不借助第三方工具,怎样查看sql的执行计划
I)使用ExplainPlan,查询PLAN_TABLE;
EXPLAINPLAN
SETSTATEMENT_ID=’QUERY1′
FOR
SELECT*
FROMa
WHEREaa=1;
SELECToperation,options,object_name,object_type,ID,parent_id
FROMplan_table
WHERESTATEMENT_ID=‘QUERY1′
ORDERBYID;
II)SQLPLUS中的SETTRACE即可看到ExecutionPlanStatistics
SETAUTOTRACEON;
3.如何使用CBO,CBO与RULE的区别
IF初始化参数OPTIMIZER_MODE=CHOOSETHEN–(8IDEFAULT)
IF做过表分析
THEN优化器Optimizer=CBO(COST);/*高效*/
ELSE
优化器Optimizer=RBO(RULE);/*高效*/
ENDIF;
ENDIF;
区别:
RBO根据规则选择最佳执行路径来运行查询。
CBO根据表统计找到最低成本的访问数据的方法确定执行计划。
使用CBO需要注意:
I)需要经常对表进行ANALYZE命令进行分析统计;
II)需要稳定执行计划;
III)需要使用提示(Hint);
使用RULE需要注意:
I)选择最有效率的表名顺序
II)优化SQL的写法;
在optimizer_mode=choose时,如果表有统计信息(分区表外),优化器将选择CBO,否则选RBO。
RBO遵循简单的分级方法学,使用15种级别要点,当接收到查询,优化器将评估使用到的要点数目,然后选择最佳级别(最少的数量)的执行路径来运行查询。
CBO尝试找到最低成本的访问数据的方法,为了最大的吞吐量或最快的初始响应时间,计算使用不同的执行计划的成本,并选择成本最低的一个,关于表的数据内容的统计被用于确定执行计划。
4.如何定位重要(消耗资源多)的SQL
使用CPU多的用户session
SELECTa.SID,spid,status,SUBSTR(a.program,1,40)prog,a.terminal,a.SQL_TEXT,osuser,VALUE/60/100VALUE
FROMv$sessiona,v$processb,v$sesstatc
WHEREc.statistic#=12ANDc.SID=a.SIDANDa.paddr=b.addr
ORDERBYVALUEDESC;
selectsql_textfromv$sql
wheredisk_reads>1000or(executions>0andbuffer_gets/executions>30000);
5.如何跟踪某个session的SQL
利用TRACE跟踪
ALTERSESSIONSETSQLTRACEON;
COLUMNSQLformata200;
SELECTmachine,sql_textSQL
FROMv$sqltexta,v$sessionb
WHEREaddress=sql_address
ANDmachine=‘&A’
ORDERBYhash_value,piece;
execdbms_system.set_sql_trace_in_session(sid,serial#,&sql_trace);
selectsid,serial#fromv$sessionwheresid=(selectsidfromv$mystatwhererownum=1);
execdbms_system.set_ev(&sid,&serial#,&event_10046,&level_12,”);
6.SQL调整最关注的是什么
检查系统的I/O问题
sar-d能检查整个系统的iostat(IOstatistics)
查看该SQL的responsetime(dbblockgets/consistentgets/physicalreads/sorts(disk))
7.说说你对索引的认识(索引的结构、对dml影响、对查询影响、为什么提高查询性能)
索引有B-TREE、BIT、CLUSTER等类型。
ORACLE使用了一个复杂的自平衡B-tree结构;通常来说,在表上建立恰当的索引,查询时会改进查询性能。
但在进行插入、删除、修改时,同时会进行索引的修改,在性能上有一定的影响。
有索引且查询条件能使用索引时,数据库会先度取索引,根据索引内容和查询条件,查询出ROWID,再根据ROWID取出需要的数据。
由于索引内容通常比全表内容要少很多,因此通过先读索引,能减少I/O,提高查询性能。
b-treeindex/bitmapindex/functionindex/patitionalindex(local/global)索引通常能提高select/update/delete的性能,会降低insert的速度,
8.使用索引查询一定能提高查询的性能吗?
为什么
通常,通过索引查询数据比全表扫描要快.但是我们也必须注意到它的代价.
索引需要空间来存储,也需要定期维护,每当有记录在表中增减或索引列被修改时,索引本身也会被修改.这意味着每条记录的INSERT,DELETE,UPDATE将为此多付出4,5次的磁盘I/O.因为索引需要额外的存储空间和处理,那些不必要的索引反而会使查询反应时间变慢.使用索引查询不一定能提高查询性能,索引范围查询(INDEXRANGESCAN)适用于两种情况:
基于一个范围的检索,一般查询返回结果集小于表中记录数的30%宜采用;
基于非唯一性索引的检索
索引就是为了提高查询性能而存在的,如果在查询中索引没有提高性能,只能说是用错了索引,或者讲是场合不同
9.绑定变量是什么?
绑定变量有什么优缺点?
绑定变量是指在SQL语句中使用变量,改变变量的值来改变SQL语句的执行结果。
优点:
使用绑定变量,可以减少SQL语句的解析,能减少数据库引擎消耗在SQL语句解析上的资源。
提高了编程效率和可靠性。
减少访问数据库的次数,就能实际上减少ORACLE的工作量。
缺点:
经常需要使用动态SQL的写法,由于参数的不同,可能SQL的执行效率不同;
绑定变量是相对文本变量来讲的,所谓文本变量是指在SQL直接书写查询条件,
这样的SQL在不同条件下需要反复解析,绑定变量是指使用变量来代替直接书写条件,查询bindvalue在运行时传递,然后绑定执行。
优点是减少硬解析,降低CPU的争用,节省shared_pool
缺点是不能使用histogram,sql优化比较困难
10.如何稳定(固定)执行计划
可以在SQL语句中指定执行计划。
使用HINTS;
que
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- oracle 开发人员 试题