第章Oracle资料学习_001.ppt

上传人:b****2 文档编号:2123343 上传时间:2022-10-27 格式:PPT 页数:32 大小:354.50KB
下载 相关 举报
第章Oracle资料学习_001.ppt_第1页
第1页 / 共32页
第章Oracle资料学习_001.ppt_第2页
第2页 / 共32页
第章Oracle资料学习_001.ppt_第3页
第3页 / 共32页
第章Oracle资料学习_001.ppt_第4页
第4页 / 共32页
第章Oracle资料学习_001.ppt_第5页
第5页 / 共32页
点击查看更多>>
下载资源
资源描述

第章Oracle资料学习_001.ppt

《第章Oracle资料学习_001.ppt》由会员分享,可在线阅读,更多相关《第章Oracle资料学习_001.ppt(32页珍藏版)》请在冰豆网上搜索。

第章Oracle资料学习_001.ppt

第11章其他表类型4本章要点:

了解临时表的特点。

熟练掌握不同类别的临时表的创建和使用。

熟练掌握外部表的创建。

掌握在创建外部表时可以指定的一些子句。

熟练掌握不同类型的分区表的创建。

掌握增加分区的不同方法。

掌握合并与删除分区的方法。

211.1临时表4在Oracle数据库中,临时表是“静态”的,它与普通的数据表一样,只需要一次创建。

4其结构从创建到删除的整个期间都是有效的。

311.1.1临时表的特点4临时表主要有如下特点:

临时表只有在用户向表中添加数据时,Oracle才会为其分配存储空间。

为临时表分配的空间来自临时表空间,这避免了与永久对象的数据争用存储空间。

在临时表中存储数据是以事务或会话为基础的。

当用户当前的事务结束或会话终止时,临时表占用的存储空间将被释放,存储的数据也随着丢失。

与堆表一样,用户可以在临时表上建立索引、视图和触发器等。

411.1.2临时表的类别4由于临时表中存储的数据只在当前事务处理或者会话进行期间有效,因此临时表主要分为两种事务级别临时表和会话级别临时表,说明如下。

(1)事务级别临时表|事务级别临时表是指临时表中的数据只在事务生命周期中存在。

事务级别临时表是指临时表中的数据只在事务生命周期中存在。

当一个事务结束当一个事务结束(提交或者回滚事务提交或者回滚事务),Oracle自动清除临时表中自动清除临时表中的数据。

的数据。

|创建事务级别临时表时,需要使用创建事务级别临时表时,需要使用ONCOMMITDELETEROWS子句。

子句。

(2)会话级别临时表|会话级别临时表是指临时表中的数据只在会话生命周期之中存在,会话级别临时表是指临时表中的数据只在会话生命周期之中存在,当用户退出,会话结束的时候,当用户退出,会话结束的时候,Oracle自动清除临时表中数据。

自动清除临时表中数据。

|创建会话级别临时表时,需要使用创建会话级别临时表时,需要使用ONCOMMITPRESERVEROWS子句。

子句。

511.1.3临时表的创建与使用41创建事务级别临时表创建临时表时,如果指定ONCOMMITDELETEROWS子句,则表示创建的临时表是事物级别临时表。

语法如下:

|CREATEGLOBALTEMPORARYTABLEtable_name(|column_namedata_type,column_namedata_type,.|)ONCOMMITDELETEROWS;42使用事务级别临时表临时表的使用方法与堆表的使用方法相同,都可以执行SELECT语句、INSERT语句等。

接下来使用前面创建的临时表temp_student执行相应的操作。

611.1.3临时表的创建与使用43创建会话级别临时表在创建临时表时,如果指定ONCOMMITPRESERVEROWS子句,则表示创建的临时表是会话级别临时表。

语法如下:

|CREATEGLOBALTEMPORARYTABLEtable_name(|column_namedata_type,column_namedata_type,.|)ONCOMMITPRESERVEROWS;44使用会话级别临时表会话级别的临时表中的数据,当用户退出会话结束时,Oracle自动清除该临时表中的数据。

接下来使用前面创建的临时表temp_book执行相应的操作。

711.1.3临时表的创建与使用45删除临时表删除临时表的操作和删除堆表的操作是一样的,都是使用DROPTABLE语句。

删除该表后,该表的相关内容也从user_tables视图中删除。

【例【例11.5】删除前面所创建的临时表temp_student,如下:

|SQLDROPTABLEtemp_student;|表已删除。

表已删除。

811.2外部表4外部表是引用在数据库以外的文件系统中存储的数据的只读表,也就是说,外部表所要读取的数据存储在Oracle数据库外部的文件中,并且只能读取这些数据,不能进行数据写入。

911.2.1使用外部表读取外部文件4创建外部表,需要在CREATETABLE语句中,添加ORGANIZATIONEXTERNAL子句,在该子句中可以指定下面所示的一些选项:

TYPE:

用来指定访问外部表数据文件时所使用的访问驱动程序,该程序可以将数据从它们最初的格式转换为可以向服务器提供的格式。

Oracle提供的默认访问驱动程序是ORACLE_LOADER。

DEFAULTDIRECTORY:

用来指定所使用的目录对象,该目录对象指向外部数据文件所在目录。

LOCATION:

用来指定源数据文件。

ACCESSPARAMETERS:

用来设置访问驱动程序进行数据格式转换时的参数。

FIELDSTERMINATEDBY:

用来指定字段之间的分隔符。

1011.2.1使用外部表读取外部文件4【例【例11.6】下面将实现外部表读取外部文件的操作。

(1)使用外部表对外部文件执行读取操作之前,首先创建外部文件。

在操作系统目录E:

external中,创建一个记录学生的图书证信息的文本文件card.txt,文件的内容如图11-1所示。

(2)创建一个目录对象,该目录对象将作为操作系统文件系统上目录的别名,用来指向数据文件位置的目录。

(3)接下来创建外部表。

创建外部表需要使用CREATETABLEORGANIZATIONEXTERNAL语句。

(4)使用SELECT语句,查询外部表e_card中的数据,如下:

|参见教材参见教材P2491111.2.2使用REJECTLIMIT子句4处理外部表错误的子句包括REJECTLIMIT、BADFILE(或NOBADFILE)和LOGFILE(或NOLOGFILE)。

本节将介绍REJECTLIMIT子句的用法。

BADFILE(或NOBADFILE)和LOGFILE(或NOLOGFILE)的用法将在后面的两个小节中进行介绍。

4在创建外部表时使用REJECTLIMIT子句,可以指定在数据类型转换期间允许出现的错误个数。

1211.2.2使用REJECTLIMIT子句4【例【例11.7】下面将介绍使用REJECTLIMIT子句,处理外部表中出现的数据类型转换错误。

(1)首先模拟使用外部表时出现的一个错误。

在创建外部表e_card时,将cardnumber列的数据类型设置为NUMBER,如下:

|参见教材参见教材P250

(2)在card.txt文件中,保存的文件内容不变,对应cardnumber列的字段仍然是非数字字符串类型。

(3)使用SELECT语句查询e_card表时,将会出现类型转换错误,如下:

|参见教材参见教材P2501311.2.2使用REJECTLIMIT子句(4)接下来,将使用REJECTLIMIT子句,处理上述错误。

重新创建表e_card,添加REJECTLIMITUNLIMITED子句,表示错误个数不受限制。

具体如下:

|参见教材参见教材P250(5)使用SELECT语句查询e_card表,如下:

|SQLSELECT*FROMe_card;|未选定行未选定行(6)如果对外部文件中的内容进行修改,使得数据类型符合转换的要求。

例如将card.txt文件中第一行数据修改为如下内容:

|参见教材参见教材P2511411.2.3使用BADFILE子句4如果指定NOBADFILE子句,则Oracle将会忽略所有数据类型转换错误。

4【例例11.8】重新创建外部表e_card,在创建时指定BADFILE子句,如下:

SQLCREATETABLEe_card(2cardidNUMBER(10),3cardnumberNUMBER(9),4studentidNUMBER(10),5registertiemDATE6)ORGANIZATIONEXTERNAL(7TYPEoracle_loader8DEFAULTDIRECTORYexternal_card9ACCESSPARAMETERS(10RECORDSDELIMITEDBYNEWLINE11BADFILEcard_bad.txt12FIELDSTERMINATEDBY,)13LOCATION(card.txt)14)REJECTLIMITUNLIMITED;表已创建。

1511.2.3使用BADFILE子句4现在使用SELECT语句查询e_card表,如下:

SQLSELECT*FROMe_card;CARDIDCARDNUMBESTUDENTIDREGISTERTIEM-12008001117-9月-094从查询结果可以看出,符合转换要求的数据可以正常显示。

而不符合转换要求的数据行将被复制到card_bad.txt文件中,该文件的内容如图11-2所示。

1611.2.4使用LOGFILE子句4LOGFILE子句用来指定一个记录错误信息的日志文件。

如果使用NOLOGFILE子句,则不会将错误信息写入任何日志文件中。

4【例【例11.9】重新创建外部表e_card,在创建时指定LOGFILE子句,如下:

参见教材P2524上面在创建e_card表时,使用LOGFILE子句指定记录错误信息的日志文件为card_log.txt,该文件将在执行上述语句时被自动创建,并与card.txt文件同目录。

4使用SELECT语句查询e_card表,则card_log.txt文件中生成的内容如图11-3所示。

1711.3分区表4在大型的数据库应用中,需要处理的数据量可以达到几十到几百GB,甚至达到TB级。

4分区表是将一个非常大的表分割成较小的片段(分区)。

4Oracle数据库对表或索引分区的方法有5种:

范围分区、散列分区、列表分区、组合范围散列分区和组合范围列表分区。

4在创建分区表时,应该根据不同类型分区表的特点,选择合适的分区类型。

1811.3.1使用RANGE关键字创建范围分区表4范围分区就是根据数据表中的某个值的范围进行分区,根据某个值的大小或次序,决定将每条数据分别存储在哪个分区上。

4在创建范围分区表之前,首先需要检查当前数据库已经存在的表空间,以便于将不同的分区指定到不同的表空间中。

1911.3.1使用RANGE关键字创建范围分区表4【例【例11.10】创建一个范围分区表,用来保存图书信息,并且根据图书的出版时间将添加的记录数据保存到不同的分区中。

(1)创建范围分区表part_book,如下:

|参见教材参见教材P254

(2)使用INSERT语句,向part_book表中添加多条记录信息。

语句如下:

|SQLINSERTINTOpart_bookVALUES(1,Oracle11g,23.5,25-11月月-07);|SQLINSERTINTOpart_bookVALUES(2,Struts2,22.8,25-11月月-08);|SQLINSERTINTOpart_bookVALUES(3,SSH,27.8,25-11月月-09);(3)使用SELECT语句检索part_book表中的数据,并且使用PARTITION关键字指定所要查看的分区。

下面检索part1和part3分区中的数据:

|SQLSELECT*FROMpart_bookPARTITION(part1);|BIDBOOKNAMEBOOKPRICEBOOKTIME|-|1Oracle11g23.525-11月月-07|SQLSELECT*FROMpart_bookPARTITION(part3);|BIDBOOKNAMEBOOKPRICEBOOKTIME|-|3SSH27.825-11月月-092011.3.2使用HASH关键字创建散列分区表4散列分区是通过HASH算法均匀分布数据的一种分区类型。

通过在I/O设备上进行散列分区,可以使得分区的大小一致。

创建散列分区需要使用PARTITIONBYHASH子句。

4【例【例11.11】创建散列分区表part_book2,使用P

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

当前位置:首页 > 考试认证 > IT认证

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1