数据仓库常见面试问题

一、 数据库

1、 Oracle数据库,视图与表的区别?普通视图与物化视图的区别?物化视图的作用?materialized view

答:a:视图是虚拟表,提高了表的安全性,视图没有实际物理空间,而表有实际存储的物理空间

         b:物化视图存储了实实在在的数据,而普通视图之存储了定义

         c:物化视图的优点像索引一样,提高查询性能。当基表发生变化时,物化视图也应当刷新。

       物化视图是数据库中的一种存储数据的对象,和表一样,存储了数据。用于预先计算并保存表连接或者聚集等耗时较多的操作。这样,在执行查询的时候,就可以避开连接、聚集等耗时的操作,从而快速的得到结果。它可以查询表,视图甚至是其他物化视图中的数据。和视图不同的是,它存储了实实在在的数据,而视图只是存储了定义而已,所以,也是可以在物化视图上创建索引的。物化视图在很多方面,和索引很相似:使用它的主要目的是为了提高查询性能;物化视图对应用是透明的,增加或者删除物化视图不会影响应用程序中查询语句的正确性和有效性;物化视图会占用存储空间;当基表发生变化时,物化视图也应当刷新。通常情况下,物化视图被称为主表(在复制期间)或者明细表(在数据仓库中)。

2、 Oracle数据库,有哪几类索引,分别有什么特点?

答:三类索引

a:B树索引

b:文本索引

c:位图索引

3、 Union与Union All的区别?

Union 会去掉重复,效率比 union all 低

4、 对游标的理解?游标的分类?使用方法?

显示游标:自己打开关闭

隐式游标:自动打开关闭

5、 如何查找和删除表中的重复数据?给出方法或SQL。

查找表中重复数据

select ID1,email from email e1
where rowid  < (select max(rowid) from email e2 where e1.email = e2.email AND e1.id1 = e2.id1);

删除表中重复数据
 delete ID1,email from email e1
 where rowid  < (select max(rowid) from email e2 where e1.email = e2.email AND e1.id1 = e2.id1);

 select ID1,email from email e1
 where rowid  > (select min(rowid) from email e2 where e1.email = e2.email AND e1.id1 = e2.id1);

6、 不借助第三方工具,怎么查看SQL的执行计划?

Set autotrace on EXPLAIN PLAN FOR

7、 创建索引有哪些需要注意的要点?

根据每个索引的特点说出建立时应注意的问题。

8、 Oracle数据库中,有哪几种分区?各自特点是什么?作用是什么?分区索引的分类和作用?

范围分区:根据某个值的范围

Hash分区:散列分区,是数据均匀分布

复合分区:先范围分区再Hash分区

增强可用性:如果表的某个分区出现故障,表在其他分区的数据仍然可用;

维护方便:如果表的某个分区出现故障,需要修复数据,只修复该分区即可;

均衡I/O:能把不同的分区映射到磁盘以平衡I/O,改善整个系统性能;

改善查询性能:对分区对象的查询能仅搜索自己关心的分区,提高检索速度。

9、 表T(a,b,c,d),要根据字段c排序后取第21—30条记录显示,请给出sql。

select * from email where rownum <=30 
minus
select * from email where rownum <=20

order by 2  //代表第二列

10、  备份如何分类?归档是什么含义?

1:     逻辑备份:exp/imp
  物理备份:
  RMAN备份
  full backup/incremental backup(累积/差异)
  热备份:alter tablespace begin/end backup;
  冷备份:脱机备份(database shutdown)

关于归档日志:Oracle要将填满的在线日志文件组归档时,则要建立归档日志(archived redo log)。
  其对数据库备份和恢复有下列用处:
  数据库后备以及在线和归档日志文件,在操作系统和磁盘故障中可保证全部提交的事物可被恢复。
  在数据库打开和正常系统使用下,如果归档日志是永久保存,在线后备可以进行和使用。

  数据库可运行在两种不同方式下:
  NOARCHIVELOG方式或ARCHIVELOG 方式数据库在NOARCHIVELOG方式下使用时,不能进行在线日志的归档,如果数据库在ARCHIVELOG方式下运行,可实施在线日志的归档。

11、 如果系统现在需要在一个很大的表上创建一个索引,需要考虑那些因素,如何做到尽量减小对应用的影响?

12、 是否有海量数据处理经验?有何方法?

https://blog.csdn.net/shujuwangzi/article/details/41412427

猜你喜欢

转载自www.cnblogs.com/gouhaiping/p/12453904.html