IT人员面试题.docx

上传人:苏美尔 文档编号:10687799 上传时间:2021-05-31 格式:DOCX 页数:12 大小:18.50KB
返回 下载 相关 举报
IT人员面试题.docx_第1页
第1页 / 共12页
IT人员面试题.docx_第2页
第2页 / 共12页
IT人员面试题.docx_第3页
第3页 / 共12页
IT人员面试题.docx_第4页
第4页 / 共12页
IT人员面试题.docx_第5页
第5页 / 共12页
点击查看更多>>
资源描述

《IT人员面试题.docx》由会员分享,可在线阅读,更多相关《IT人员面试题.docx(12页珍藏版)》请在三一文库上搜索。

1、IT招聘面试题ORACLE数据库面试题悬赏分:100-解决时间:2009-9-2718:50下面是一个公司的数据库题目, 我没用过oracle ,不过貌似题目用sql就可以写,不知道他 们把这个题目写成 oracle有什么蹊跷,我意思是这到题目有什么地方是 oracle特别需要注 意的,希望强人作答!谢谢一、数据库ORACLE虽然这些题目都可以 G至L但还是要考察一下您现在的常态水平,:)T 表:(字段:ID, NAME , ADDRESS, PHONE , LOGDATE )E表:(字段: NAME , ADDRESS , PHONE )1 .将表T中的字段LOGDATE中为2001-02-

2、11的数据更新为 2003-01-01 ,请写出相应的SQL语句。(该字段类型为日期类型)2 .请写出将表T中NAME存在重复的记录都列出来的SQL语句(按NAME排序)3 .请写出题目2中,只保留重复记录的第一条,删除其余记录的SQL语句(即使该表不存在重复记录)4 .请写出将E表中的ADDRESS、PHONE更新到T表中的SQL语句(按NAME相同进行 关联)5 .请写出将T表中第35行数据列出来的 SQL语句1.updatetsetlogdate=to_date(2003-01-01,yyyy-mm-dd)wherelogdate=to_date(2001-02-11,yyyy-mm-d

3、d);2.select* fromtwherenamein(selectnamefromtgroupbynamehavingcoung(*)1) orderbyname;-没说清楚,到底是升序还是降序3.selectID , NAME , ADDRESS , PHONE , LOGDATE from (selectt.*,row_number()over(partitionbynameorderbyname)rn fromt)wherern=1;4.updatetset(address,phone尸(selectaddress,phonefromewheree.name=t.name);5.s

4、elect*fromtwhererownum=5minusselect*fromtwhererownum=2;Oracle面试题悬赏分:10-解决时间:2009-10-2008:28今天遇到的一道电信方面面试题:A表有以下字段:month(月份),user_id(用户编号),user_state(用户状态,0为正常用户, 1为非正常用户)。如果某一个用户上月为正常用户,本月为非正常用户,则成为流失用户。查询:200505 年的流失用户的用户编号。问题补充:我是这么做的,能查出来,但他们公司的DBA说效率太低,太麻烦!selectuseridfromaalwheretime=200505ands

5、tate=1and(selectstatefromaa2wherea1.userid=a2.useridandtime=200504)=0selectuseridfromtablewhereuser_state=1andmonth=5anduseridin(selectuseridfromtablewheremonth=4anduser_state=0);(谁能给出答案?)/colorORG-机构表:ORGIDORGNAME001国有商业银行0011中国工商银行0012中国建设银行ORGRLT-机构汇总关系表子机构需要将各种报表数据汇总到父机构,即如果要求“国有商业银行”的报表数据,那么需要将

6、中国工商银行和中国建设银行”的报表数据汇总一下(2家机构的报表的每个单元格的数据值相加),然后将报表的机构ID改为“国有商业银行”即可PARENTORGIDCHILDORGID00100110010012REPORTDATA-报表数据表:REPIDREPNAMEREPDATEORGIDCELLIDVALUE001 资产负债表 2009-03-3100111A1700.0000001 资产负债表 2009-03-3100111B2900.0000REPORTTOTAL汇总表报表数据:REPIDINT-报表 ID 号REPNAMEVARCHAR(50)-报表名称REPDATEDATE-报表上报日期

7、ORGIDCHAR(17)-机构 ID 号CELLIDINT-报表单元格ID号VALUEDECIMAL(30,4)-报表单元格的值问题:向”父机构报表数据表“中插入一张2009年3月31号的国有商业银行,”资产负债表的数据,*只能使用一条SQL语句楼上的答案是错的,集函数是不能这么用的以下是正确答案,可以包含多级所属关系insertintoREPORTTOTAL(REPID,REPNAME,REPDATE,ORGID,CELLIDTOTAL_VALUE)selectrepid,repname,repdate,(selectorgidfromorgwhereorgname=国有商业车艮行),1A

8、,sum(value)fromreportdata whereREPNAME= 资产负债表andREPDATE=2009-03-31andordidin/* 找到所有子机构 ORGID*/(selectCHILDORGIDfromORGRLTconnectbyparentorgid=priorchildorgidstartwithparentorgid=(selectorgidfromorgwhereorgname= 国有商业专艮行)groupbyrepid,repname,repdate)/* 使用报告 ID ,名称,日期分组 */帮忙解决一道数据库面试题悬赏分:20 -解决时间:2009-

9、3-1217:28在Oracle数据库中有一张表 A编号名称1a2b3c4d如何写一条SQL语句,显示以下结果ab,ac,ad,bc,cdselectdistincta.name|b.name|,|a.name|c.name|,|a.name|d.name|,|b.name|c.name|,|c.name|d.namefromAa,Ab,Ac,Adwherea.number=1andb.number=2andc.number=3andd.number=41 .解释冷备份和热备份的不同点以及各自的优点解答:热备份针对归档模式的数据库,在数据库仍旧处于工作状态时进行备份。而冷备份指在数据库关闭后,

10、进行备份,适用于所有模式的数据库。热备份的优点在于当备份时,冷备份的优点在于它的备数据库仍旧可以被使用并且可以将数据库恢复到任意一个时间点。份和恢复操作相当简单,并且由于冷备份白数据库可以工作在非归档模式下,数据库性能会比归档模式稍好。(因为不必将archivelog 写入硬盘)2 .你必须利用备份恢复数据库,但是你没有控制文件,该如何解决问题呢?解答:重建控制文件,用带 backupcontrolfile子句的recover命令恢复数据库。3 .如何转换 init.ora 到 spfile?解答:使用 createspfilefrompfile 命令4 .解释datablock,extent

11、 和segment的区别(这里建议用英文术语)解答:datablock是数据库中最小的逻辑存储单元。当数据库的对象需要更多的物理存储空间时,连续的datablock 就组成了 extent. 一个数据库对象拥有的所有extents被称为该对象的 segment.5 .给出两个检查表结构的方法解答:1、DESCRIBE命令6 、DBMS_METADATA.GET_DDL 包7 .怎样查看数据库引擎的报错解答:alertlog.8 .比较 truncate 和 delete 命令解答:两者都可以用来删除表中所有的记录。区别在于:truncate 是DDL操作,它移动 HWK ,不需要 rollba

12、cksegment. 而 Delete 是 DML 操作需要 rollbacksegment 且花费 较长时间.9 .使用索引的理由解答:快速访问表中的datablock10 给出在STARSCHEMA中的两种表及它们分别含有的数据解答:Facttables 和dimensiontables.facttable包含大量的主要的信息而dimensiontables 存放对facttable 某些属性描述的信息11 .FACTTable 上需要建立何种索引?解答:位图索引(bitmapindex )12 .给出两种相关约束?解答:主键和外键13 .如何在不影响子表的前提下,重建一个母表解答:子表的

13、外键强制实效,重建母表,激活外键14 .解释归档和非归档模式之间的不同和它们各自的优缺点解答:归档模式是指你可以备份所有的数据库transactions并恢复到任意一个时间点。非归档模式则相反,不能恢复到任意一个时间点。但是非归档模式可以带来数据库性能上的 少许提高15 .如何建立一个备份控制文件?解答:Alterdatabasebackupcontrolfiletotrace.16 .给出数据库正常启动所经历的几种状态?解答:STARTUPNOMOUNT-数据库实例启动STARTUPMOUNT -数据库装载STARTUPOPEN -数据库打开17 .哪个column 可以用来区别 V$视图和

14、GV$视图?解答:INST_ID指明集群环境中具体的某个instance 。18 .如何生成 explainplan?解答:运行utlxplan.sql.建立plan表针对特定 SQL语句,使用explainplansetstatementjd=tst1intoplan_table运行 utlxplp.sql 或 utlxpls.sql 察看explainplan19 .如何增加 buffercache 的命中率?解答:在数据库较繁忙时,适用buffercacheadvisory 工具,查询v$db_cache_advice. 如果有必要更改,可以使用altersystemsetdb_cach

15、e_size 命令19.ORA-01555 的应对方法?解答:具体的出错信息是 snapshottoooldwithinrollbackseg,通常可以通过增大rollbackseg 来解决问题。当然也需要察看一下具体造成错误的SQL文本20 .解释 $ORACLE_HOME 和$ORACLE_BASE 的区另解答:ORACLE_BASE是oracle的根目录,ORACLE_HOME 是oracle 产品的目录21 .如何判断数据库的时区?解答:SELECTDBTIMEZONEFROMDUAL;22 .解释GLOBAL_NAMES 设为TRUE的用途解答:GLOBAL_NAMES指明联接数据库

16、的方式。如果这个参数设置为TRUE,在建立数据库链接时就必须用相同的名字连结远程数据库23。如何加密PL/SQL程序?解答:WRAP24 .解释 FUNCTION,PROCEDURE和 PACKAGE 区另解答:function 和procedure 是PL/SQL代码的集合,通常为了完成一个任务。 procedure 不需要返回任何值而function 将返回一个值在另一方面,Package是为了完成一个商业功能的一组 function 和proceudre 的集合25 .解释 TABLEFunction 的用途解答:TABLEFunction 是通过PL/SQL逻辑返回一组纪录,用于普通的

17、表/视图。他们也用于pipeline 和ETL过程。26 .举出 3 种可以收集 threeadvisorystatistics解答:BufferCacheAdvice,SegmentLevelStatistics,TimedStatistics27 .Audittrace存放在哪个oracle目录结构中?解答:unix$ORACLE_HOME/rdbms/auditWindowstheeventviewer28 .解释 materializedviews的作用解答:Materializedviews用于减少那些汇总,集合和分组的信息的集合数量。它们通常适合于数据仓库和DSS系统。29 .当用

18、户进程出错,哪个后台进程负责清理它解答:PMON30 .哪个后台进程刷新materializedviews?解答:TheJobQueueProcesses.31 .如何判断哪个session正在连结以及它们等待的资源?解答:V$SESSION/V$SESSION_WAIT32 .描述什么是redologs可以用来修复数解答:RedoLogs是用于存放数据库数据改动状况的物理和逻辑结构。据库.33 .如何进彳亍强制 LOGSWITCH?解答:ALTERSYSTEMSWITCHLOGFILE;34 .举出两个判断DDL改动的方法?解答:你可以使用 Logminer 或Streams35 .Coal

19、escing 做了什么?解答:Coalescing 针对于字典管理的 tablespace 进行碎片整理,将临近的小extents合并成单个的大extent.36 .TEMPORARYtablespace 和 PERMANENTtablespace 的区另是?解答:Atemporarytablespace用于临时对象例如排序结构而permanenttablespaces用来存储那些真实的对象(例如表,回滚段等)37 .创建数据库时自动建立的tablespace 名称?解答:SYSTEMtablespace.38 .创建用户时,需要赋予新用户什么权限才能使它联上数据库。解答:CONNECT39

20、.如何在tablespace 里增加数据文件?解答:ALTERTABLESPACEADDDATAFILESIZE40 .如何变动数据文件的大小?解答:ALTERDATABASEDATAFILERESIZE;41 .哪个VIEW用来检查数据文件的大小?解答:DBA_DATA_FILES42 .哪个VIEW用来判断tablespace 的剩余空间解答:DBA_FREE_SPACE43 .如何判断谁往表里增加了一条纪录?解答:auditing44 .如何重构索引?解答:ALTERINDEXREBUILD;45 .解释什么是Partitioning (分区)以及它的优点。解答:Partition 将大

21、表和索引分割成更小,易于管理的分区。46 .你刚刚编译了一个 PL/SQLPackage但是有错误报道,如何显示出错信息?解答:SHOWERRORS47 .如何搜集表的各种状态数据?解答:ANALYZETheANALYZEcommand.48 .如何启动 SESSION级别的TRACE解答:DBMS_SESSION.SET_SQL_TRACEALTERSESSIONSETSQL_TRACE=TRUE;49.IMPORT 和SQL*LOADER 这2个工具的不同点解答:这两个 ORACLE工具都是用来将数据导入数据库的。区别是:IMPORT工具只能处理由另一个 ORACLE工具EXPORT生成的数据。而SQL*LOADER可以导入不同的 ASCII格式的数据源50。用于网络连接的2个文件?解答:TNSNAMES.ORAandSQLNET.ORA以上就是个人收集整理的 OracleDBA 面试题,祝大家面试顺利。要是有别的好的OracleDBA 面试题希望大家回帖!

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 科普知识


经营许可证编号:宁ICP备18001539号-1