数据库程序员面试分类真题13.docx
《数据库程序员面试分类真题13.docx》由会员分享,可在线阅读,更多相关《数据库程序员面试分类真题13.docx(26页珍藏版)》请在三一办公上搜索。
1、下:SYSdbSHOWPARAMErtRBACKGRouND_DUMP_DEST眦三VA1.UEteckgnxnd_&n)jieststring/uOl/冲/OradeainlhrMlflP在OraCleIlg中,告警日志一般在$ORAC1.E_BASE/diag/rdbms/$DBNAME/$ORAC1.E_SID/traca目录下:S,SglhrdbSHOWPARAMETERBACKGROUNDDUMPDEST7faa三三VAUEbac11xmd.(tapjcststring1WleapMTttediag,dtas.Ohrdb.ih11lbtraceZFZU1.HRDlOTckloraci
2、cdECbaPPgJcldjgi11sdbfeaZF2H1.HRDB1:OTdorade*ocJt姬hftmdtra0ls-Ia!0t*11rIoradfISmMmin1JO42Oct1713akrt_lhrdbJos从OraCIe12.1.0.1开始,参数BACKGRoUND_DUMP_DEST己废弃,告警日志的位置应该由以下SQ1.来查询:SQ1.SE1.ECTd.VA1.UEFROMV$DIAGNFodWHEREd.NAME=DiagTrace,;VA1.UEv三*w三MWVWu1/apporaele/diagrdbms/1hrdblhrdbtrace需要注意的是,该SQ1.也适用于Or
3、aCleUg的版本。3. 若告警志文件过大,则如何有效管理告警志文件?正确答案:由于告警日志按时间的先后顺序不断累积存储,久而久之,势必造成告警日志的过大,难以维护,查找相关的信息也不方便。另外,若告警日志超大,也会严市影响系统的性能。这里提供3种办法来管理告警日志:使用外部表方式来管理告警日志将大大简化维护工作量,也可以更直观地获取所需的信息;视图V$DTAG_A1.ERT_EXT对应的基表里存储了告警日志的内容,可以根据该视图将告警日志的内容行储在历史表中;利用SHE1.1.脚本定时将告警日志进行备份,防止告警日志过大而影响系统性能。4. 数据库处于RESTRICT、QUIESCE和SUS
4、PEND状态的区别是什么?正确答案:在OraCle中,数据库可以有3种限制性状态,见下表。RESTWQUlEScISUSPENDR介011k,W哪删锚i腓.而胸稣作游谢H族不燃用跳户脚460.打这相如皿解魁人RISIWE)SESSION财,底祭止做用户化戏如与湖眸以RESTRIer槌泊功.成槌入RKlWCT崎,0ral三明物M睇糜肺期胞蝴丸A曲RESTRICTEDSEsSK)X觊姻沪驹RESTRICTZit三三IP三1TW.豌配询用户可腰的闸W邮,翎州Kff8RESnUCr用WlESCE腿脓6却懒,他NDBA胁训啊珊恨阳副胪不触所操作,1ft-ftfQUIESCEWRJDBAR取棚IfM以选旗
5、作,而制用户封6于等外轧JU当J根库迅出QUESCE婢制护推他t三,QnKeU迷肝724瑞提HHi传醐,好蹈护硫乂躁憾年酗硼洲强筋松螂RESTRICTB!制的是兴有RESTOCTtDsession-kw.他场颜护无液m.ftQl三EWW-SYS.S三M用户的时S三怡战鼓、确,DM1.ESuWEND主要跟SO用中肺用户的K)M的,覆辩好SUSPEND处EEfcQ岫曲,W2胞用网啊以正名盼.口副期执仔ft三J幅裸可跳BufcCKhe帔知利起蝌10.4t不会胡最旗代询强将削。姆才会圈第的盘颔嬲RKTRKI是黎止网即1U焉而对侬更姻户设舐版1果期服票止l三户的桶,mi三eif三iffi三j耨会乐并机m
6、s三0N微作.RESiwcn身题糊颂物,对典舲话坳建过谀耳系我的QuEScERES11UCHD.WDBAflf处F到懒,府苜蝴迷是湿存侬措造用户部集无蝴行郴作,醺系起出Ql三CEtt.QUESCE自检筱蒯融股点f三SQim骸用帕好嫦修也是懒轴了晒SQ1.iif1.QuESCE喘怫话微力搦行会楸RACWftRESTRICT幡麻RAC耳搬侬初明相魏物价做RESTRICr根浣轴油版嬲犹aQl三会物耍懂斛柘跣嫡,HRAC州徽联无法在QUESCE悔下制SUSreNDR加细饰RAC知生虬酸悯的灼,ftmAcnXE艇,SlSPENDifWbW能用钟SuRnjPRKTMCT;一启防醴翎期A1.三SYSTEME
7、KAB1.ERESTRICTEDSESSIoN:-启用A1.TERSYsrEMDISAB1.ERI三ICH)SEsSloY一鞠Grantrestricto)sessionto1.HR;-三RMxERESJRiCTtDS三ONFROMM-Sft三AnERSYSTEMQl三IRME)T现A1.TERSYSTEMUNQUIESCE;-?i给A1.TERsYsnMSUSpEMb自用A1.TERSYSTEMRESUMErIifi处僦SE1.ECT1.OGINSFROMGVSINsTANCEIE常处为A1.1.OftlD.RESTWCT状态下为RESTRICTEDSE1.ECTDAEzsTAreFROMV
8、snstanceDrH常状器为NORMA1.QITESCEUTQb三H)SE1.ECTnDATABASE_STAMFROMVSINSTANaDr正穗为AemEQClESa悔下为SISPENDED脑瞄A1.T1.RSYsIEMubrouadSiSSjo11:Dtmhseisce11xfe&spatin$MOUNT-OPEN,详细情况见下表。阶&缄任务I注自令NoMOlNr腿便实懒)蝴融函NrtM务:1)技以F财在SORAe1.EJIOMEdlB!Windousf台网ORAC1.EH0ME%-fa3bw股)睫下赞奸icorai!tra2)源”陆械SGA3)职昭M4)打开腿改也吉文的曜文件策段多肝雎
9、胞也视文件棘、特定的德诙娘,融注复艇.就段和ff三如戏即敝件.在IWAN快姐,醴觑mm三三fSTARTUPNOMOUKT(线)腿赖W任务各注自今MO1.NTSMiM(Wr阶胱眦任务好:1)用用参也攵件中的CWTRO1.Fl1.ES的值.打开制1定投制文件2)移费拓与实用知遑泉3)潮文件用网射8攵件gRdo日告文件的名聊脑做1,但不如Ii得岫城件麻舱该阶段多用于以F坛第D雷奇名醵文件,硼爆文师(W掰而及弼W三3iF也可以篁钝懿文件)2)附强谏哨州苜版3)发醵爆库的完域Uxsm.这与蝴避敢件,跟这一步有的醐矫鼓翻,嬲Im激动STARTUPMOUNTOreN雕OreN松段剧的的如En三Mlift2)
10、m三瞅件喊雕要M以机fi:D-1.QnldC神肺的寐文件就机潴文件暨看打开制映眯笈静G2)m处出现致性M1.脓SMoN鼾曜动宾WMl3)如I任富一M件飙机球如款,勒IOnKle跚物会报珞STARWP6. 关闭数据库有几种方式?正确答案:数据库的关闭也有一些参数需要注意,关闭命令为SHUTDOWNABORTIIMMEDIATETRANSACTIONA1.NORMA1.其中,SHUTDOWN不带参数将默认为ORMA1.0一般情况卜.,关闭数据库都使用uSHUTDOWNIMMEDIATE命令。这几个参数的区别见卜表。YYYNNNNNYSHUTDOWNNORMA1.TRANSACTIONA1.IMME
11、DIATEABORT是否允许新连m接NNNN告警日志ShuttingdownShuttingdowninstanceShuttingdowninstanceShuttingdowninstance(normal)(transactional)(immediate)instance(abort)1)NORMA1.表示不准许新的连接,等待当前所有连接到数据库系统的用户都断开连接(DlSCONXECT),强制检查点并关闭文件,卜次启动不需要实例恢复。2)TRANSAc11onale表示不准许新的连接,不允许开启新事务,数据库等待所有事务完成后断开当前连接到数据库的所有用户,强制检查点并关闭文件,下次
12、启动不需要实例恢复。3) IMMEDlATE表示不准许新的连接,不允许开启新事务,任何未提交的事务都进行回滚。数据库显式回滚活动的事务并断开所有当前连接到数据库的用户,强制检查点并关闭文件,下次启动不需要实例恢且。4) ABORT表示不准许新的连接,不允许开启新事务,任何未提交的事务不进行回滚。数据库立刻中断所有SQ1.的执行,并断开所有用户的连接。不做强制检杳点,下次启动需要做实例恢熨。7. 索引包括那几个特性?正确答案:一般来说索引有3大特性,即索引高度比较低、索引存储列值及索引本身有序,对这3大特性的应用见下表。索引特性带来的优势应用的常见SQ1.高度比较低索引高度低有利于索引范围扫描,
13、通过索引可以非常迅速地从这也是索引存储列值索引本身有序海量数据中获取少量数据的原因。索引的高度越高,访问索引需要读取的数据块数越多,效率越差由于索引比表一般要小得多,所以在通过索引本身就可以查找到所需要的数据的情况卜.,可以将表看成是一个“瘦表”或“小表”,无须索引回表读这个过程(索引回表读是非常耗费性能的),这样访问路径就会大大减少。利用该特性可以优化的SQ1.包括COUNT(*).SUM(索引例J)等聚合语句能够利用索引本身已有的排序特性来消除目标SQ1.的排序操作,从而优化ORDERBY等排序语句能够用索引有序的特性在叶广块的最左边或最右边找到最小和最大值,从而优化类型MAX、VIN语句
14、SE1.ECT*FROMTWHEREID=I;SE1.ECTCOUNT(*)FROMT;SE1.ECTSUM(OBJECT_ID)FROMT:SE1.ECT*FROMTWHEREOBJECT_ID2ORDERBYOBJECT.ID;SE1.ECTMAX(OBJECT_ID)FROMT:另外,需要特别注意的是,索引不存储空值。考点索引8. 如何预估即将创建索引的大小?正确答案:如果当力表大小是1TB,那么在某一列上创建索引的话索引大概占用多大的空间?对于这个问题,Oracle提供了2种可以预估将要创建的索引大小的办法:D利用系统包DBMSSPACE.CREATEINDEXCoST直接得到。利用D
15、BMSSPACE.CRETETAB1.ECoSTnj以获得将要创建的表的大小。2)利用OraCIeUg薪特性NOTERAISEDWHENEXP1.AINP1.ANFORCREATEINDEXo考点索引9. 如何监控索引的使用状况?正确答案:在开发应向程序时,可能会建立很多索引,那么这些索引的使用到底怎么样,是否有些索引一直都没有用到过,在这种情况下就需要对这些索引进行监控,以便确定它们的使用情况,并为是否可以清除它们给出依据。监控索引有两种方式:(D直接监控索引的使用情况1)设置所要监控的索引:A1.TERINDEXIDX_T_XXMONITORINGUSAGE;2)查看该索引有没有被使用:S
16、E1.ECT*FROMV$OBJECT-USAGE;3)关闭监控:A1.TERINDEXIDX_T_XXNOMONITORINGUSAGE;查询V$0BJEe1.uSAGE就可以知适薪据库对索引的使用情况。通过一段时间的监控,就可以确定哪些是无用的索引。另外,为了避免使用V$0BJECTUSAGE只能查询到当前用户下索引的监控情况,可以使用如下语句查询数据库中所有被监控索引的使用情况:SE1.ECTU.NAMEOWNER,10.NAMEINDEX_NAME,T.NAMETB1.E-NAME,DECODE(BITAND(I.F1.AGS,65536、,0,NO,YES)MONITORING,DE
17、CODE(BITND(OU.F1.AGS,1),0,NO,YES)USED,OU.STARTMONITORINGSTARTMONITORING,OU.ENDMONITORINGENDMONITORINGFROMSYS.USERSU,SYS.OBJJIO,SYS.OBJ$T.SYS.INDSI,SYS.OBJECT.USGEOUWHERE1.OBJ#=OU.OBJ#AND10.OBJtt=OU.OBJttANDT.OBJ#=1.BOttANDU.USERit=IO.OWNER#;(2)通过查看历史的执行计划,分析索引的使用情况可以从视图DBAJI1STSQl-P1.AN中获取到数据库中所有索引的
18、扫描次数情况,然后根据扫描次数和开发人员沟通是否需要保留索引。考点索引10. 哪些操作会导致索引失效?正确答案:当某些操作导致数据行的ROwlD改变,索引就会完全失效。可以分普通表和分区表来讨论哪些操作将导致索引失效。D普通表索引失效的情形如下:手动置索引无效:A1.TERINDEXIND_OBJECT_1DUNUSAB1.E;。如果对表进行MOVE操作(包含移动表空间和血缩操作)或在线重定义表后,那么该表上所有的索引状态会变为UNUSAB1.E。MoVE操作的SQ1.语句为A1.TERTAB1.ETTMOVE;。SQ1.*1.oader加载数据。在SQ1.*1.Oader加载过程中会维护索引
19、,由于数据量比较大,在SQ1.*1.oadcr加载过程中出现异常情况,也会导致OraCle来不及维护索引,导致索引处于失效状态,影响杳询和加载。异常情况主要有在加载过程中杀掉SQ1.*1.oader进程、重启或表空间不足等。2)分区表索引失效的情形如下:对分区表的某个含有数据的分区执行了TRUNCATEDROP操作可以导致该分区表的全局索引失效,而分区索引依然有效,如果操作的分区没有数据,那么不会影响索引的状态。需要注意的是,对分区表的ADD操作对分区索引和全局索引没有影响。执行EXCHANGE操作后,全局索引和分区索引都会被无条件地置为UNUSAB1.E(无论分区是否含有数据).但是,若包含
20、INC1.UDINGINDEXES子句(默认情况下为EXCUJDlNGINDEXES),则全局索引会失效,而分区索引依然有效。如果执行Sp1.lT的目标分区含有数据,那么在执行SP1.lT操作后,全局索引和分区索引都会被置为UNUSAB1.Eo如果执行SP1.IT的目标分区没有数据,那么不会影响索引的状态。对分区表执行MOVE操作后,全局索引和分区索引都会被置于无效状态。手动置其无效:A1.TERINDEXINDOBJECTIDUNUSAB1.E;对于分区表而言,除了ADD操作之外,TRUNCATE.DROP、EXCHANGE和SP1.lT操作均会导致全局索引失效,但是可以加上UPDATEG1
21、.OBA1.INDEXES子句让全局索引不失效。重建分区索引的命令为A1.TERINDEXIDX_RAM1.1.HRREBUI1.DPARTITIONPl;o考点索引11. 聚簇因子-(ClusteringFaCtOr)是什么?正确答案:OraCIe数据库中最普通、最为常用的即为堆表,堆表的数据存储方式为无序存储,当对数据进行检索的时候,柞常消耗资源,这个时候就可以为表创建索引了。在索引中,数据是按照一定的顺序排列起来的。当新建或重建索引时,索引列上的顺序是有序的,而表上的顺序是无序的,这样就存在了差异,即表现为聚簇因子(ChaSteringFactor,CF),也称为群集因子或集群因子等,本
22、书统一称为聚簇因子。聚簇因子值的大小对CBO判断是否选择相关的索引起者至关重要的作用。在Oracle数据库中,聚簇因f是指按照索引键值排序的索引行和存储于时应表中数据行的存储顺序的相似程度,也就是说,衣中数据的存储顺序和某些索引字段顺序的符合程度。CF是基于表上索引列上的个值,每一个索引都有一个CF值。Oracle按照索引块所存储的ROWTD来标识相邻索引记录在表块中是否为相同块。好的CF值接近于表上的块数,而差的CF值则接近于表上的行数。CF值越小,相似度越高,CF值越大,相似度越低。如果CF的值接近块数,那么说明表的存储和索引存储排序接近,也就是说表中的记录很有序,这样在做IM)EXRAN
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据库 程序员 面试 分类 13
链接地址:https://www.31ppt.com/p-7141769.html