oracle从入门到精通(PDF格式)-第15部分
按键盘上方向键 ← 或 → 可快速上下翻页,按键盘上的 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