DB笔试面试390Oracle的外部表是什么?

Posted DB宝

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了DB笔试面试390Oracle的外部表是什么?相关的知识,希望对你有一定的参考价值。


【DB笔试面试390】Oracle的外部表是什么?


Q
题目

 

Oracle的外部表是什么?




     

A
答案


外部表是指不存在于数据库中的表。通过向Oracle提供描述外部表的元数据,可以把一个操作系统文件当成一个只读的数据库表,就像这些数据存储在一个普通数据库表中一样来进行访问。外部表是对数据库表的延伸。外部表只能在Oracle 9i之后的版本来使用。

Oracle外部表用来存取数据库以外的文本文件(Text File)或Oracle专属格式文件。因此,建立外部表时不会产生段、区、数据块等存储结构,只有与表相关的定义放在数据字典中。外部表仅供查询,不能对外部表的内容进行修改(例如INSERTUPDATEDELETE等操作)。不能在外部表上建立索引。因为创建索引就意味着要存在对应的索引记录,而其实外部表的数据没有存储在数据库中,故在外部表上是无法建立索引的。

如果外部表采用PARALLEL的方式加载的话,那么加载的数据是无序的。所以,这种情况需要综合考虑,尤其是在使用该方式来查看告警日志文件内容的时候需要特别注意。

外部表有如下几点特性:

① 外部表的数据位于文件系统之中,按一定格式分割文本文件或者其它类型的表可以作为外部表。操作系统文件在数据库中的标志是通过一个逻辑目录来映射的,所以外部表需要在Oracle数据库“服务端”创建目录,这些OS文件必须放在这些目录中。

② 对外部表的访问可以通过SQL语句来完成,而不需要先将外部表中的数据装载进数据库中。

③ 外部表是只读的,因此,只能对外部表进行SELECT操作,不能外部表执行DMLDELETEUPDATEINSERT等)操作,也不能创建索引但是可以创建视图,也可以创建同义词。

④ ANALYZE语句不支持采集外部表的统计数据,应该使用DMBS_STATS包来采集外部表的统计数据。

⑤ 可以对外部表执行查询、连接和并行操作。

⑥ 外部表不支持LOB对象。

与外部表相关的几个视图如下所示

SELECT * FROM DBA_EXTERNAL_LOCATIONS; --描述外部表的位置

SELECT * FROM DBA_EXTERNAL_TABLES;--所有的外部表

SELECT * FROM DBA_DIRECTORIES;--数据库中所有的目录对象




【DB笔试面试390】Oracle的外部表是什么?


DB笔试面试历史连接

http://mp.weixin.qq.com/s/Vm5PqNcDcITkOr9cQg6T7w

【DB笔试面试390】Oracle的外部表是什么?

About Me:小麦苗

 本系列题目来源于作者的学习笔记,部分整理自网络,若有侵权或不当之处还请谅解

 版权所有,欢迎分享本文,转载请保留出处

● 题目解答若有不当之处,还望各位朋友批评指正,共同进步

【DB笔试面试390】Oracle的外部表是什么?


以上是关于DB笔试面试390Oracle的外部表是什么?的主要内容,如果未能解决你的问题,请参考以下文章

数据库笔试面试题库(OracleMySQL等)

DB笔试面试164在Oracle中,如何彻底停止expdp数据泵进程?

DB笔试面试225在Oracle中,如果联机Redo日志文件损坏,那么如何恢复?

DB笔试面试202在Oracle中,怎样清除V$ARCHIVED_LOG视图中的过期信息?

DB笔试面试275 有关shell脚本的一些题目

新书出版 |《数据库程序员面试笔试宝典》