数据库面试题目- ORACLE

Posted on 2009-06-08 17:38 漠北的天空 阅读(111) 评论(0)  编辑 收藏 1.       列举几种表链接方式 Answer:等链接(内链接)、非等链接、自链接、外链接(左、右、全) Or hash join/merge join/nest loop(cluster join)/index join ?? ORACLE 8i,9i 表链接方法。   通常的相等链接: select * from a, b where a.id = b.id; 这个就属于内链接。   对于外链接: Oracle中可使用“(+) ”来表示,9i可使用LEFT/RIGHT/FULL OUTER JOIN   LEFT OUTER JOIN:左外关联 SELECT e.last_name, e.department_id, d.department_name FROM employees e LEFT OUTER JOIN departments d ON (e.department_id = d.department_id); 等价于 SELECT e.last_name, e.department_id, d.department_name FROM employees e, departments d WHERE e.department_id=d.department_id(+) 结果为:全部员工及对应部门的记录,包括没有对应部门编号department_id的员工记录。   RIGHT OUTER JOIN:右外关联 SELECT e.last_name, e.department_id, d.department_name FROM employees e RIGHT OUTER JOIN departments d ON (e.department_id = d.department_id); 等价于 SELECT e.last_name, e.department_id, d.department_name FROM employees e, departments d WHERE e.department_id(+)=d.department_id 结果为:全部员工及对应部门的记录,包括没有任何员工的部门记录。   FULL OUTER JOIN:全外关联 SELECT e.last_name, e.department_id, d.department_name FROM employees e FULL OUTER JOIN departments d ON (e.department_id = d.department_id); 结果为:全部员工及对应部门的记录,包括没有对应部门编号department_id的员工记录和没有任何员工的部门记录。   ORACLE8i是不直接支持彻底外链接的语法,也就是说不能在左右两个表上同时加上(+),下面是在ORACLE8i能够参考的彻底外链接语法 select t1.id,t2.id from table1 t1,table t2 where t1.id=t2.id(+) union select t1.id,t2.id from table1 t1,table t2 where t1.id(+)=t2.id       链接类型 定义 图示 例子 内链接 只链接匹配的行 select A.c1,B.c2 from A join B on A.c3 = B.c3; 左外链接 包含左边表的所有行(无论右边的表中是否存在与它们匹配的行)以及右边表中所有匹配的行 select A.c1,B.c2 from A left join B on A.c3 = B.c3; 右外链接 包含右边表的所有行(无论左边的表中是否存在与它们匹配的行)以及左边表中所有匹配的行 select A.c1,B.c2 from A right join B on A.c3 = B.c3; 全外链接 包含左、右两个表的所有行,无论在另外一边的表中是否存在与它们匹配的行 select A.c1,B.c2 from A full join B on A.c3 = B.c3; (theta)链接 使用等值之外的条件来匹配左、右两个表中的行 select A.c1,B.c2 from A join B on A.c3 != B.c3; 交叉链接 生成笛卡尔积——它不使用任何匹配或者选取条件,而是直接将一个数据源中的每一个行与另外一个数据源的每一个行一一匹配   select A.c1,B.c2 from A,B;   2.       不借助第三方工具,怎样查看sql的执行计划 I) 使用Explain Plan,查询PLAN_TABLE;    EXPLAIN   PLAN       SET STATEMENT_ID='QUERY1'       FOR       SELECT *       FROM a       WHERE aa=1;    SELECT    operation, options, object_name, object_type, ID, parent_id        FROM plan_table       WHERE STATEMENT_ID = 'QUERY1'    ORDER BY ID; II)SQLPLUS中的SET TRACE 便可看到Execution Plan Statistics    SET AUTOTRACE ON; 3.       如何使用CBO,CBO与RULE的区别    IF 初始化参数 OPTIMIZER_MODE = CHOOSE THEN   --(8I DEFAULT)       IF 作过表分析          THEN 优化器 Optimizer=CBO(COST);           /*高效*/       ELSE          优化器 Optimizer=RBO(RULE);                /*高效*/       END IF;    END IF;      区别:    RBO根据规则选择最佳执行路径来运行查询。    CBO根据表统计找到最低成本的访问数据的方法肯定执行计划。    使用CBO须要注意:    I)   须要常常对表进行ANALYZE命令进行分析统计;    II) 须要稳定执行计划;    III)须要使用提示(Hint);    使用RULE须要注意: I)   选择最有效率的表名顺序 II) 优化SQL的写法;     在optimizer_mode=choose时,若是表有统计信息(分区表外),优化器将选择CBO,不然选RBO。 RBO遵循简单的分级方法学,使用15种级别要点,当接收到查询,优化器将评估使用到的要点数目,而后选择最佳级别(最少的数量)的执行路径来运行查询。 CBO尝试找到最低成本的访问数据的方法,为了最大的吞吐量或最快的初始响应时间,计算使用不一样的执行计划的成本,并选择成本最低的一个,关于表的数据内容的统计被用于肯定执行计划。 4.       如何定位重要(消耗资源多)的SQL 使用CPU多的用户session SELECT a.SID, spid, status, SUBSTR (a.program, 1, 40) prog, a.terminal,a.SQL_TEXT, osuser, VALUE / 60 / 100 VALUE FROM v$session a, v$process b, v$sesstat c WHERE c.statistic# = 12 AND c.SID = a.SID AND a.paddr = b.addr ORDER BY VALUE DESC;   select sql_text from v$sql where disk_reads &gt; 1000 or (executions &gt; 0 and buffer_gets/executions &gt; 30000); 5.       如何跟踪某个session的SQL 利用TRACE 跟踪    ALTER SESSION SET SQLTRACE ON;    COLUMN SQL format a200;    SELECT    machine, sql_text SQL        FROM v$sqltext a, v$session b       WHERE address = sql_address         AND machine = '&A'    ORDER BY hash_value, piece;   exec dbms_system.set_sql_trace_in_session(sid,serial#,&amp;sql_trace); select sid,serial# from v$session where sid = (select sid from v$mystat where rownum = 1); exec dbms_system.set_ev(&amp;sid,&amp;serial#,&amp;event_10046,&amp;level_12,''); 6.       SQL调整最关注的是什么 检查系统的I/O问题 sar-d能检查整个系统的iostat(IO statistics)   查看该SQL的response time(db block gets/consistent gets/physical reads/sorts (disk)) 7.       说说你对索引的认识(索引的结构、对dml影响、对查询影响、为何提升查询性能) 索引有B-TREE、BIT、CLUSTER等类型。ORACLE使用了一个复杂的自平衡B-tree结构;一般来讲,在表上创建恰当的索引,查询时会改进查询性能。但在进行插入、删除、修改时,同时会进行索引的修改,在性能上有必定的影响。有索引且查询条件能使用索引时,数据库会先度取索引,根据索引内容和查询条件,查询出ROWID,再根据ROWID取出须要的数据。因为索引内容一般比全表内容要少不少,所以经过先读索引,能减小I/O,提升查询性能。   b-tree index/bitmap index/function index/patitional index(local/global)索引一般能提升select/update/delete的性能,会下降insert的速度, 8.       使用索引查询必定能提升查询的性能吗?为何 一般,经过索引查询数据比全表扫描要快.可是咱们也必须注意到它的代价. 索引须要空间来存储,也须要按期维护, 每当有记录在表中增减或索引列被修改时,索引自己也会被修改. 这意味着每条记录的INSERT,DELETE,UPDATE将为此多付出4,5 次的磁盘I/O. 由于索引须要额外的存储空间和处理,那些没必要要的索引反而会使查询反应时间变慢.使用索引查询不必定能提升查询性能,索引范围查询(INDEX RANGE SCAN)适用于两种状况: 基于一个范围的检索,通常查询返回结果集小于表中记录数的30%宜采用; 基于非惟一性索引的检索   索引就是为了提升查询性能而存在的,若是在查询中索引没有提升性能,只能说是用错了索引,或者讲是场合不一样 9.       绑定变量是什么?绑定变量有什么优缺点? 绑定变量是指在SQL语句中使用变量,改变变量的值来改变SQL语句的执行结果。 优势:使用绑定变量,能够减小SQL语句的解析,能减小数据库引擎消耗在SQL语句解析上的资源。提升了编程效率和可靠性。减小访问数据库的次数, 就能实际上减小ORACLE的工做量。 缺点:常常须要使用动态SQL的写法,因为参数的不一样,可能SQL的执行效率不一样;   绑定变量是相对文本变量来说的,所谓文本变量是指在SQL直接书写查询条件, 这样的SQL在不一样条件下须要反复解析,绑定变量是指使用变量来代替直接书写条件,查询bind value在运行时传递,而后绑定执行。 优势是减小硬解析,下降CPU的争用,节省shared_pool 缺点是不能使用histogram,sql优化比较困难 10.   如何稳定(固定)执行计划 能够在SQL语句中指定执行计划。使用HINTS; query_rewrite_enabled = true star_transformation_enabled = true optimizer_features_enable = 9.2.0 建立并使用stored outline 11.   和排序相关的内存在8i和9i分别怎样调整,临时表空间的做用是什么 SORT_AREA_SIZE 在进行排序操做时,若是排序的内容太多,内存里不能所有放下,则须要进行外部排序, 此时须要利用临时表空间来存放排序的中间结果。   8i中sort_area_size/sort_area_retained_size决定了排序所须要的内存, 若是排序操做不能在sort_area_size中完成,就会用到temp表空间 9i中若是workarea_size_policy=auto时, 排序在pga内进行,一般pga_aggregate_target的1/20能够用来进行disk sort; 若是workarea_size_policy=manual时,排序须要的内存由sort_area_size决定, 在执行order by/group by/distinct/union/create index/index rebuild/minus等操做时,若是在pga或sort_area_size中不能完成,排序将在临时表空间进行(disk sort),临时表空间主要做用就是完成系统中的disk sort. 12.   存在表T(a,b,c,d),要根据字段c排序后取第21—30条记录显示,请给出sql      SELECT    *          FROM (SELECT ROWNUM AS row_num, tmp_tab.*                  FROM (SELECT    a, b, c, d                            FROM T                        ORDER BY c) tmp_tab                 WHERE ROWNUM <= 30)         WHERE row_num >= 20 ORDER BY row_num;   create table t(a number(,b number(,c number(,d number(); / begin for i in 1 .. 300 loop insert into t values(mod(i,2),i/2,dbms_random.value(1,300),i/4); end loop; end; / select * from (select c.*,rownum as rn from (select * from t order by c desc) c) where rn between 21 and 30; / select * from (select * from test order by c desc) x where rownum &lt; 30 minus select * from (select * from test order by c desc) y where rownum &lt; 20 order by 3 desc 相比之 minus性能较差 二:数据库基本概念类 1 Pctused and pctfree 表示什么含义有什么做用 pctused与pctfree控制数据块是否出如今freelist中,   pctfree控制数据块中保留用于update的空间,当数据块中的free space小于pctfree设置的空间时,该数据块从freelist中去掉,当块因为dml操做free space大于pct_used设置的空间时,该数据库块将被添加在freelist链表中。 2 简单描述tablespace / segment / extent / block之间的关系 tablespace: 一个数据库划分为一个或多个逻辑单位,该逻辑单位成为表空间;每个表空间可能包含一个或多个 Segment; Segments: Segment指在tablespace中为特定逻辑存储结构分配的空间。每个段是由一个或多个extent组成。包括数据段、索引段、回滚段和临时段。 Extents: 一个 extent 由一系列连续的 Oracle blocks组成.ORACLE为经过extent 来给segment分配空间。 Data Blocks:Oracle 数据库最小的I/O存储单位,一个data block对应一个或多个分配给data file的操做系统块。 table建立时,默认建立了一个data segment,每一个data segment含有min extents指定的extents数,每一个extent据据表空间的存储参数分配必定数量的blocks 3 描述tablespace和datafile之间的关系 一个表空间可包含一个或多个数据文件。表空间利用增长或扩展数据文件扩大表空间,表空间的大小为组成该表空间的数据文件大小的和。一个datafile只能属于一个表空间; 一个tablespace能够有一个或多个datafile,每一个datafile只能在一个tablespace内, table中的数据,经过hash算法分布在tablespace中的各个datafile中,tablespace是逻辑上的概念,datafile则在物理上储存了数据库的种种对象。 4 本地管理表空间和字典管理表空间的特色,ASSM有什么特色 本地管理表空间:(9i默认)空闲块列表存储在表空间的数据文件头。 特色:减小数据字典表的竞争,当分配和收缩空间时会产生回滚,不须要合并。 字典管理表空间:(8i默认)空闲块列表存储在数据库中的字典表里. 特色:片由数据字典管理,可能形成字典表的争用。存储在表空间的每个段都会有不一样的存储字句,须要合并相邻的块;   本地管理表空间(Locally Managed Tablespace简称LMT) 8i之后出现的一种新的表空间的管理模式,经过位图来管理表空间的空间使用。字典管理表空间(Dictionary-Managed Tablespace简称DMT) 8i之前包括之后都还可使用的一种表空间管理模式,经过数据字典管理表空间的空间使用。动段空间管理(ASSM),它首次出如今Oracle920里有了ASSM,连接列表freelist被位图所取代,它是一个二进制的数组, 可以迅速有效地管理存储扩展和剩余区块(free block),所以可以改善分段存储本质,ASSM表空间上建立的段还有另一个称呼叫Bitmap Managed Segments(BMB 段)。 5 回滚段的做用是什么 回滚段用于保存数据修改前的映象,这些信息用于生成读一致性数据库信息、在数据库恢复和Rollback时使用。一个事务只能使用一个回滚段。   事务回滚:当事务修改表中数据的时候,该数据修改前的值(即前影像)会存放在回滚段中,当用户回滚事务(ROLLBACK)时,ORACLE将会利用回滚段中的数据前影像来将修改的数据恢复到原来的值。 事务恢复:当事务正在处理的时候,例程失败,回滚段的信息保存在undo表空间中,ORACLE将在下次打开数据库时利用回滚来恢复未提交的数据。 读一致性:当一个会话正在修改数据时,其余的会话将看不到该会话未提交的修改。 当一个语句正在执行时,该语句将看不到从该语句开始执行后的未提交的修改(语句级读一致性) 当ORACLE执行SELECT语句时,ORACLE依照当前的系统改变号(SYSTEM CHANGE NUMBER-SCN) 来保证任何前于当前SCN的未提交的改变不被该语句处理。能够想象:当一个长时间的查询正在执行时, 若其余会话改变了该查询要查询的某个数据块,ORACLE将利用回滚段的数据前影像来构造一个读一致性视图 6 日志的做用是什么 日志文件(Log File)记录全部对数据库数据的修改,主要是保护数据库以防止故障,以及恢复数据时使用。其特色以下:    a)每个数据库至少包含两个日志文件组。每一个日志文件组至少包含两个日志文件成员。    b)日志文件组以循环方式进行写操做。    c)每个日志文件成员对应一个物理文件。   记录数据库事务,最大限度地保证数据的一致性与安全性   重作日志文件:含对数据库所作的更改记录,这样万一出现故障能够启用数据恢复,一个数据库至少须要两个重作日志文件 归档日志文件:是重作日志文件的脱机副本,这些副本可能对于从介质失败中进行恢复很必要。 7 SGA主要有那些部分,主要做用是什么 系统全局区(SGA):是ORACLE为实例分配的一组共享缓冲存储区,用于存放数据库数据和控制信息,以实现对数据库数据的管理和操做。 SGA主要包括: a)共享池(shared pool) :用来存储最近执行的SQL语句和最近使用的数据字典的数据。 b)数据缓冲区 (database buffer cache):用来存储最近从数据文件中读写过的数据。 c)重做日志缓冲区(redo log buffer):用来记录服务或后台进程对数据库的操做。 另外在SGA中还有两个可选的内存结构: d)Java pool:   用来存储Java代码。 e)Large pool: 用来存储不与SQL直接相关的大型内存结构。备份、恢复使用。   GA:db_cache/shared_pool/large_pool/java_pool db_cache: 数据库缓存(Block Buffer)对于Oracle数据库的运转和性能起着很是关键的做用,它占据Oracle数据库SGA(系统共享内存区)的主要部分。Oracle数据库经过使用LRU算法,将最近访问的数据块存放到缓存中,从而优化对磁盘数据的访问. shared_pool: 共享池的大小对于Oracle 性能来讲都是很重要的。共享池中保存数据字典高速缓冲和彻底解析或编译的的PL/SQL 块和SQL 语句及控制结构 large_pool: 使用MTS配置时,由于要在SGA中分配UGA来保持用户的会话,就是用Large_pool来保持这个会话内存使用RMAN作备份的时候,要使用Large_pool这个内存结构来作磁盘I/O缓存器 java_pool: 为java procedure预备的内存区域,若是没有使用java proc,java_pool不是必须的 8 Oracle系统进程主要有哪些,做用是什么 数据写进程(DBWR):负责将更改的数据从数据库缓冲区高速缓存写入数据文件 日志写进程(LGWR):将重作日志缓冲区中的更改写入在线重作日志文件 系统监控   (SMON): 检查数据库的一致性若有必要还会在数据库打开时启动数据库的恢复 进程监控   (PMON): 负责在一个Oracle 进程失败时清理资源 检查点进程(CKPT):负责在每当缓冲区高速缓存中的更改永久地记录在数据库中时,更新控制文件和数据文件中的数据库状态信息。 归档进程   (ARCH):在每第二天志切换时把已满的日志组进行备份或归档 恢复进程   (RECO): 保证分布式事务的一致性,在分布式事务中,要么同时commit,要么同时rollback; 做业调度器(CJQ ):   负责将调度与执行系统中已定义好的job,完成一些预约义的工做. 三:备份恢复类 1 备份如何分类 逻辑备份:exp/imp 指定表的逻辑备份 物理备份: 热备份:alter tablespace begin/end backup; 冷备份:脱机备份(database shutdown) RMAN备份 full backup/incremental backup(累积/差别)   物理备份 物理备份是最主要的备份方式。用于保证数据库在最小的数据库丢失或没有数据丢失的状况下获得恢复。 冷物理 冷物理备份提供了最简单和最直接的方法保护数据库因物理损坏丢失。建议在如下几种状况中使用。 对一个已经存在大最数据量的数据库,在晚间数据库能够关闭,此时应用冷物理备份。 对需对数据库服务器进行升级,(如更换硬盘),此时须要备份数据库信息,并在新的硬盘中恢复这些数据信息,建议采用冷物理备份。 热物理 主要是指备份过程在数据库打开而且用户可使用的状况下进行。须要执行热物理备份的状况有: 因为数据库性质要求不间断工做,于是此时只能采用热物理备份。 因为备份的要求的时间过长,而数据库只能短期关闭时。 逻辑备份 (EXP/IMP) 逻辑备份用于实现数据库对象的恢复。但不是基于时间点可彻底恢复的备份策略。只能做为联机备份和脱机备份的一种补充。 彻底逻辑备份 彻底逻辑备份是将整个数据库导出到一个数据库的格式文件中,该文件能够在不一样的数据库版本、操做系统和硬件平台之间进行移植。 指定表的逻辑备份 经过备份工具,能够将指定的数据库表备份出来,这能够避免彻底逻辑备份所带来的时间和财力上的浪费。 2 归档是什么含义  关于归档日志:Oracle要将填满的在线日志文件组归档时,则要创建归档日志(archived redo log)。其对数据库备份和恢复有下列用处: 数据库后备以及在线和归档日志文件,在操做系统和磁盘故障中可保证所有提交的事物可被恢复。 
相关文章
相关标签/搜索