八宝书库 > 文学其他电子书 > oracle从入门到精通(PDF格式) >

第15部分

oracle从入门到精通(PDF格式)-第15部分

小说: oracle从入门到精通(PDF格式) 字数: 每页4000字

按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 Enter 键可回到本书目录页,按键盘上方向键 ↑ 可回到本页顶部!
————未阅读完?加入书签已便下次继续阅读!






                               第 62 页,共 106 页 


…………………………………………………………Page 63……………………………………………………………

资源来自网络,仅供学习!                                              Oracle 从入门到精通 



      *、 MOUNT 状态下执行;  

          目标文件必须存在;  

          ALTER DATABASE RENAME FILE 'old_name'TO'new_name';  



9、删除表空间:  



    不能删除的状态:是 SYSTEM 表空间;  

                  有激活回滚段的表空间;  

    DROP TABLESPACE space_name INCLUDING CONTENTS AND DATAFILES 'CASCADE CONSTRAINTS';  



19、存储结构和关系  



  数据块  

  区:空间扩展的单位  

  段和数据文件的关系:  

  组成段的所有区必须在段表空间的数据文件上;  



1、段类型:  



       1。   表  

       2。   表分区:  

             分区表(partitioned table):分了多个区的表,单表多段,存储海量数据;  

             特点:  

                  容量大;性能好;  

             分类:  

                  范围  

                  散列  

                  列表:按单点的值进行分区;               



       3。   簇表(cluster):多表单段;  

             表和表有共同的字段,公用字段只存储一次;  

             减少存储空间,查询速度快;  

             全表扫描的时间增长;  



      4。   索引  

       5。   索引组织表(index…organized table):将字段索引和字段值放在一个表中,没有物 

          理的 rowid。  

             查找索引字段值非常快,其他字段的查询却非常慢;  

             单表单段;  



       6。   索引分区  

       7。  回滚段:保证事务回滚(存放原始数据);  

       8。  临时段  

       9。   大对象段  

       10。 签到表:多维表才会用到;  

       11。 引导段:初始化数据字典信息;  



                             第 63 页,共 106 页 


…………………………………………………………Page 64……………………………………………………………

资源来自网络,仅供学习!                                                  Oracle 从入门到精通 



2、区:        



  是段在表空间上使用的连续空间  

  当段执行下列操作的时候分配区:  

    Created 段创建  

    Extended 段扩展  

    Altered 手动分配  

  当段执行下列操作的时候释放区:  

    Droped   

    Altered   

    Truncated   



3、数据库块  



  最小的 I/O单位  

  有一个或多个操作系统块组成  

  可以在表空间创建时分配  

  DB_BLOCK_SIZE 参数设置默认块的大小  



4、9I提供非标准块  



  数据库可以使用一个标准块和四个非标准块创建;  

  快的大小可以是 2KB 到32KB 之间的任意一个 2 的N 次方数;  

  好处:对数据的操作特性上,在做查询的时候减少 I/O 使用;  



5、标准块大小  



    在数据库创建的时候通过 DB_BLOCK_SIZE parameter 参数设置。在数据库创建以后不能被修 

  改。  

    SYSTEM 和 TEMPORARY 临时表空间必须使用  

    DB_CACHE_SIZE 设置了标准块对应的数据高速缓存中 DEFAULT 池的大小  

    DEFAULT 池的大小:  

       最小是 4M 或 16M  默认为 48M  



6、非标准块的大小  



       使用下列参数配置对应的数据高速缓存:  

       DB_2K_CACHE_SIZE FOR 2 KB BLOCKS   

       DB_4K_CACHE_SIZE FOR 4 KB BLOCKS  

       DB_8K_CACHE_SIZE FOR 8 KB BLOCKS  

       DB_16K_CACHE_SIZE FOR 16 KB BLOCKS  

       DB_32K_CACHE_SIZE FOR 32 KB BLOCKS  

    DB_nK_CACHE_SIZE 不允许使用与标准块对应的参数。   



                               第 64 页,共 106 页 


…………………………………………………………Page 65……………………………………………………………

资源来自网络,仅供学习!                                             Oracle 从入门到精通 



7、数据块的内容:  



     1。   块头:  

             自顶向下递增  

             事务槽:通过事务槽来表示锁定的事务,如果想执行事务必须先获得事务槽。  



     2。   空闲空间:没有碎片  

     3。   数据:自底向上递增  



8、块的空间利用参数:  



    INITRANS  初始事务数(事务槽的个数:平常并发事务的个数)  

    MAXTRANS  最大事务数(最大事务槽数)   

    PCTFREE   为 UPDATE 保留空间的百分比;如果没有 UPDATE操作设置为零。   

    PCTUSED   标识数据块什么时候可以成为可用状态(FREELIST)  

          FREELIST 可用数据块状态  

  当块没有空间后,会构建新的块,并在原块里保留指针制向新块,但性能下降(行迁移)。   



9、数据块管理:  



  设置好之后不能更改。  

    1、自动空间管理:(默认)  

      管理数据库的段中空闲的一种方法:  

      使用 bitmap用 0 或1 标识不可用或可用状态。  

      只能在表空间级上才能设置:  

      在 CREATE TABLESPACE 语句最后加上 SEGMENT SPACE MANAGEMENT AUTO;  

      限制:不能用于包含了 LOB(大对象)对象的表空间。  

    2、手动管理:  

      可以使用下面的参数手动配置数据块:  

      PCTFREE  PCTUSED  FREELIST  

  得到存储信息:          

    DBA_EXTENTS    查看区信息  

    DBA_SEGMENTS   查看段信息  

    DBA_TABLESPACES 查看表空间信息  

    DBA_DATA_FILES  查看数据文件信息   

    DBA_FREE_SPACE  查看空闲空间信息  

    



10、管理回滚段(Undo)的数据  



     管理方法:  

       1。  自动 Undo 管理  

      2。  手动 Undo 管理  

      回滚段的原理:  

    用来暂时保存事务中的原始数据,至少保存到事务结束,保留到事务结束后回滚段中的空间 

  被其他事务覆盖之前;  

    作用:  



                             第 65 页,共 106 页 


…………………………………………………………Page 66……………………………………………………………

资源来自网络,仅供学习!                                             Oracle 从入门到精通 



     1。  事务回滚;  

     2。  事务恢复;  

     3。  读一致性;  

               在事务提交后查询,是在被查询表中查询的;  

               如果在事务执行中并发查询,数据库会在回滚段中取得数据,但正在并发查 

          询的时候事务提交就会产生读一致性错误的问题。  

    特性:  

          1。  最少需要两个区;              

          2。  使用区是以循环的方式使用;  

          3。  一个事务只能使用一个回滚段(事务不能跨回滚段);  

          4。  在一个回滚段上可以有多个事务(多个事务可以共享一个回滚段),每个事务使 

             用不同的区;  

          5。  在一个区中可以同时有多个事务的数据,但只能有一个活动的事务。  

          6。  事务对区的使用是连续的,当他将要写的下一个区有活动的事务时,它就会执 

             行扩展区操作;    

  长时间执行事务不提交,会造成阻碍会话。  

  减小事务大小,提交次数高一些,避免区扩展操作;  



20、Undo 段的类型:   



1。NON…SYSTEM类型:  



    自动模式:需要一个 UNDO 类型的表空间。(默认)设计为最少 200M,一般是几个 G。  

        配置参数:  UNDO_MANAGEMENT = AUTO/MANUAL 自动/手动  

                  UNDO_TABLESPACE = tablespace_name      

        提供足够大的 UNDO 类型表空间;  

   可以创建多个回滚类型的表空间,但只有一个是被使用的,当做切换操作的时候才需要多个表 

空间。  

     切换:正在运行的事务可以切换。              

     可以在创建数据库的 CREATE DATABASE 命令中增加一个子句创建 UNDO 表空间:  

      CREATE DATABASE database_name  

      。。。。。。。  

      undo tablespace space_name datafile 'filepath' size nM autoextend on  

      或  

      使用 CREATE UNDO TABLESPACE 命令创建:  

      create undo tablespace space_name datafile 'filepath' size nM ;      

    手动模式:  

             需要一个永久类型的表空间  

             私有:被单个实例使用  

             公有:被任意实例使用  

  DEFERRED :当表空间被修改为 OFFLINE ;IMMEDIATE,TEMPORARY,RECOVERY 状态时候出现。  



2。SYSTEM类型:  



    用于 SYSTEM 表空间的对象。  



                             第 66 页,共 106 页 


…………………………………………………………Page 67……………………………………………………………

资源来自网络,仅供学习!                                                     Oracle 从入门到精通 



    修改一个 UNDO 表空间:  

    alter tablespace space_name add datafile 'filepath' size nM autoextend on;  

    

    切换 UNDO 表空间:  

    可以从一个 UNDO 表空间切换到另一个。  

    在实例中一次只能使用一个 UNDO 表空间。  

    多个 UNDO 表空间可以存放在一个实例中,但只有一个是激活的。  

    使用 ALTER SYSTEM 命令动态切换 UNDO 表空间。  

    ALTER SYSTEM set UNDO_TABLESPACE = space_name;  

    

    删除 UNDO 表空间:  

    drop tablespace space_name;  

    UNDO 只是在当前实例没有使用它的时候才可以删除。  

    为了删除一个激活的 UNDO 表空间:  

    切换到一个新的 UNDO 表空间;  

    当所有表空间上的当前事务结束后删除表空间;    



3。自动UNDO段管理的其他参数:    



    UNDO_SUPPRESS_ERRORS parameter  

    设置为 TRUE,可以压制在 AUTO 模式下执行手动管理命令时的错误。   

    UNDO_RETENTION  parameter  

    控制为了保证读一致性而保留在提交后回滚段中数据的时间。  

    查看 UNDO 段信息:  

  SELECT。。。 FROM VUNDOSTAT;回滚段的使用频度  

  DBA_ROLLBACK_SEGS  

    



21、管理表    



  rowid 格式:伪列。  

    扩展型(extended)  

           组成:数据对象号(data object number)、相对文件号(relative file number)、 

     块号(block number)、行号(row number)(每个号6 个字节)  

           由 18 个字母组织的,存成 60 个字节,代表一行数据的绝对地址  

     限制型(restrcted)  

           组成:块号(block number)、行号(row number)、文件号(file number)  

       

  exec DBMS_ROWID 包(backage)  

  SELECT 。。。DBMS_ROWID。 。。。FROM table_name;  



1。创建表提示:  



           将表创建在独立的表空间中;  

           使用本地管理;  

           表使用标准的区大小来避免在表空间上产生碎片;                       



                                 第 67 页,共 106 页 


…………………………………………………………Page 68……………………………………………………………

资源来自网络,仅供学习!                                                 Oracle 从入门到精通 



        在创建各种文件的时候最好都有它们独立的表空间支持。  



2。创建临时表  



  CREATE GLOBAL TEMPORARY TABLE   

  。。。。。。。  

    特征:  

          用户创建的临时表是用户的会话独占的;  

          表在事务或会话过程中包含数据;  

          只会有结构而不会有存储;  

          在数据上不会得到 DML锁;  

          对该表所做的 DML 操作不会写到日志上;  

          不用做 DELETE 或TRUNCATE 操作,该表在内存中,当事务结束或会话结束时释放;  

          可以在临时表上创建索引、视图、触发器;    



3。修改存储参数和块空间利用参数:  



       alter table owner。table_name  

       pctfree 30//块参数  

       pctused 50//块参数  

       storage(next 500k minextents 2 maxextents 120);//存储参数  



4。手动分配区:  



  alter table hr。employe

返回目录 上一页 下一页 回到顶部 0 0

你可能喜欢的