select username,session_num,tablespace from v$sort_usage;

Block:

  1. 块的组成

    1. Header:包含数据块的概要信息:块地址,块属于哪个段,还有段的类型
    2. 表目录:数据所属的表的信息。
    3. 行目录:插入行的逻辑地址
    4. 预留的空余空间:
    5. 行数据区:
  2. 获取关于块的信息:
    show parameter db_block_size
    select block_size from dba_tablespaces where tablespace_name='SYSTEM';

  3. 块大小的调整:一般来说是8k,必须在建库以后指定,现在允许在不同的表空间可以有不同块大小。
    show parameter cache_size
    alter system set db_16k_cache_size=100m; --16k的设置生效
    CREATE TABLESPACE tb16k BLOCKSIZE 16K DATAFILE '/path/to/datafile' size 100m autoextend on extent management local segment space management auto;
    对比查看两个表空间:
    select tablespace_name, block_size from dba_tablespaces where tablespace_name in ('TB16K','SWAT');

  4. 块剩余空间:PCTFREE
    1. 用途:用于避免行迁移。
    2. 使用范围:全局有一个10,具体针对不同的表(segment)的特性(如经常更新的表和只读的表就不一样)可以设不同的值。

Extent:

  1. 数据字典表user_extents包含的内容: 
    1. 上级信息:段名(和类型),分区名,表空间名,
    2. 自身信息:区id,字节数,块数。
  2. 区的大小设置:
    1. 一般oracle是自动分配,可以是8个块64k,也可以是128个块1m.
    2. 在创建表空间的时候可以在extent管理后面加上uniform size 10m 来手工指定。
      create tablespace tbs_ex10m datafile '/path/to/datafile.dbf' size 100m extent management local uniform size 10m segment space management auto;
      create table t2(id int) tablespace tbs_ex10m;

Segment: 表和索引是分开的segment

 

Tablespace:

  1. 表空间分类

    1. 系统表空间
    2. 临时表空间
    3. 回滚表空间
    4. 用户表空间
  2. 创建表空间
    1. 普通表空间

      CREATE TABLESPACE name
      DATAFILE '/path/to/datafile.dbf' SIZE 100M
      EXTENT MANAGEMENT local
      SEGMENT SPACE MANAGEMENT auto;

    2. 临时表空间
      CREATE TEMPORARY TABLESPACE name
      TEMPFILE '/path/to/datafile.dbf' SIZE 100M;

    3. 回滚段表空间
      CREATE UNDO TABLESPACE name
      DATAFILE '/path/to/datafile.dbf' SIZE 100M;

  3. 查看表空间相关的参数
    1. 数据字典dba_data_files:
      1. 数据库操作系统文件信息:文件名,文件号,
      2. 对应的表空间:表空间名,字节数,块数,状态,相关文件号,自动加区,最大字节,最大块数,加区增量,用户字节,用户块数,在线状态
      3. 没有all/user_data_files
    2. 查阅普通表空间的文件名
      COL FILE_NAME FORMAT A50
      SET LINESIZE 1000
      SELECT FILE_NAME,TABLESPACE_NAME,AUTOEXTENSIBLE,BYTES
      FROM DBA_DATA_FILES WHERE TABLESPACE_NAME='tablesapcename'ORDER BY SUBSTR(FILE_NAME,-12);

    3. 查阅临时表空间的文件名
      SELECT FILE_NAME, AUTOEXTENSIBLE,BYTES
      FROM DBA_TEMP_FILES WHERE TABLESPACE_NAME='tablesapcename'
      ORDER BY SUBSTR(FILE_NAME,-12);

    4. 查看所有表空间
      SELECT TABLESPACE_NAME,FILE_NAME, AUTOEXTENSIBLE,BYTES FROM DBA_DATA_FILES;
      SELECT TABLESPACE_NAME,FILE_NAME, AUTOEXTENSIBLE,BYTES FROM DBA_TEMP_FILES;

    5. 查看永久空间类型
      SELECT TABLESPACE_NAME,CONTENTS FROM DBA_TABLESPACES;

    6. 创建用户时指定默认表空间
      CREATE USER username IDENTIFIED BY passwd DEFAULT TABLESPACE name TEMPORARY TABLESPACE name;

    7. 在默认表空间内查EXTENT相关信息
      col TAB format a10
      col TS format a10
      select segment_name TAB,extent_id,tablespace_name TS, bytes/1024 K, blocks from user_extents where rownum<100;

    8. 查看SEGMENT相关信息:哪个表空间?占用多少资源:块,区,字节?使用那个共享池buffer_pool?
      select segment_name,segment_type,tablespace_name,blocks,extents,bytes/1024/1024 M from user_segments where segment_name='T5C';

    9. 查看表空间剩余多少:从DBA_FREE_SPACE里面查
      select sum(bytes)/1024/1024 from dba_free_space where tablespace_name='SWAT';

    10. 查看表空间有多少空间:从DBA_DATA_FILES里面查
      select SUM(BYTES)/1024/1024 from dba_DATA_FILES where tablespace_name='SWAT';

    11. 表空间不足有两种方法:1.对表空间加数据文件。2.对数据库的数据文件打开自动扩展。
      ALTER TABLESPACE TBS_XX ADD DATAFILE '/path/to/datafilexxx.dbf' size 100m;
      ALTER DATABASE DATAFILE '/path/to/datafilexxx.dbf' autoextend on;

    12. 删除表空间,创建可自动增长的表空间:
      drop tablespace tb16k including contents and datafiles;
      create tablespace tbs_xxx datafile '/path/to/datafilexxx.dbf' size 100m autoextend on next 64k maxsize 5G;

    13. 回滚段表空间:undo表空间可以多个,当前只能使用1个(RAC环境例外)
      show parameter undo
      select tablespace_name, status from dba_tablespaces where contents='UNDO';
      alter system set undo_tablespace=undotbs2 scope=both;

    14. 建用户时可以指定表空间和临时表空间
      SELECT DEFAULT_TABLESPACE, TEMPORARY_TABLESPACE FROM DBA_USERS WHERE USERNAME='SWAT';
      ALTER DATABASE DEFAULT TEMPORARY TABLESPACE temp02;

    15. 临时表空间组:dba_tablespace_groups为同一个用户在不同的session配不同的临时表空间,减少IO竞争,分配时自动分配空间给特定session。
      create temporary tablespace temp1_1 tempfile '/tmp/temp01.dbf' size 10m tablespace group tmpgrp1;
      create temporary tablespace temp1_2 tempfile '/tmp/temp02.dbf' size 10m tablespace group tmpgrp1;

      select * from dba_tablespace_groups;

      create temporary tablespace temp1_3 tempfile '/tmp/temp03.dbf' size 10m;

      alter tablespace temp1_3 tablespace group tempgrp1;

      alter user SWAT temporary tablespace tmpgrp1;

      select username,session_num,tablespace from v$sort_usage;

Oracle逻辑体系:数据文件黑盒的内在洞天的更多相关文章

  1. Oracle 逻辑体系

    Oracle 逻辑体系 主题 Oracle 逻辑体系 参考资料   Oracle 逻辑体系   表空间.模式.用户.段.区.块 Oracle中的数据逻辑上存储于表空间,物理上则存储于属于表空间tabl ...

  2. oracle 11g dbf数据文件从C盘迁移到D盘

    服务器系统为 windows 2008 R2 64位,由于C盘空间将满,要将C盘的oracle的DBF数据文件迁移到D盘下,步骤如下: 1.输入cmd,启动 cmd.exe窗口 2.输入 sqlplu ...

  3. 浅谈Oracle中物理结构(数据文件等。。。)与逻辑结构(表空间等。。。。。)

    初始Oracle时很难理解其中的物理结构和逻辑结构,不明白内存中和硬盘中文件的区别和联系,我也是初学Oracle,这里就简单的谈谈我我看法. 首先,你需要明白的一点是:数据库的物理结构是由数据库的操作 ...

  4. ORACLE模拟一个数据文件坏块并使用RMAN备份来恢复

    1.创建一个实验用的表空间并在此表空间上创建表 create tablespace blocktest datafile '/u01/oradata/bys1/blocktest.dbf' size ...

  5. oracle数据库单个数据文件的大小限制

    之前没有仔细想过这个问题,因为总是不会用到,也没有犯过类似错误. 顺便提一下学习方法吧. 卤肉的学习方法是:常用知识点,熟悉理论并反复做实验,深入理解:不常用的知识点,相关内容都了解大概,遇到问题时想 ...

  6. Oracle 10g DG 数据文件迁移

    背景:某客户Oracle 10g 的DG由于空间不足,之前将部分数据文件迁移到其他目录,如今原目录扩容成功,要将之前迁移的数据文件再次迁移回来. 环境:Oracle 10.2.0.5 DG 单机 首先 ...

  7. Oracle OMF管理数据文件

    1.什么是OMF? Oracle managed file的缩写,简单的理解,就是oracle自己管理自己的文件,可以是dbf,redolog 等等,具体可以参考官方文档Adiministrator中 ...

  8. oracle数据库丢失数据文件、控制文件、重做日志文件、初始化文件恢复方法

    rman  target/ list backup; 查看是否已备份,如果没有,那就不知道了 模拟故障,删除/u01/app/oracle/oradata/ORCL文件夹下的所有文件 sqlplus ...

  9. Linux环境下利用句柄恢复Oracle误删除的数据文件

    在误删除Oracle的数据文件后,如果未关闭数据库,文件句柄还没有释放,且被删除的数据文件占用的磁盘块未被复写,则可以利用句柄的方式来恢复数据文件.下面模拟恢复过程. (一)环境 OS版本:redha ...

随机推荐

  1. 虚拟机的MAC地址分配与修改

    虚拟世界的MAC地址 先看一下真实世界的MAC地址是如何分配,如何保证没有重复的.每块网卡都有一个MAC地址,MAC地址是一个6字节.也即48bit的数据.前3字节称为OUI ,是由IEEE组织注册给 ...

  2. compass做雪碧图

    由于最近没什么时间好好写博文,我把用sass做雪碧图的关键点贴出来方便自己记忆: config.rb注释 # Set this to the root of your project when dep ...

  3. LPSTR、LPCSTR、LPWSTR、LPCWSTR、LPTSTR、LPCTSTR的来源及意义

    1. Unicode字符集: 它是用两个字节表示一个字符的方法.比如字符'A'在ASCII下面是一个字符,可'A'在UNICODE下面是两个字符,高字符用0填充,而且汉字'程'在ASCII下面是两个字 ...

  4. ASP.Net 验证控件 CompareValidator

    CompareValidator 作用就是比较两个输入框所输入的值是否一致,常用来作为验证输入密码和确认密码的业务. 属性 描述 Operator 比较操作符,可选值DataTypeCheck.Equ ...

  5. AspxGridView ComboBoxComlum列数据联动

    第1步: 页面放置AspxGridView控件, 设置列ComboBox1, ComboBox2列, 拟通过ComboBox1列更新联动ComboBox2列. 两个数据列均为"ComboBo ...

  6. nodemanager启动失败

    yarn启动报错: 2016-11-16 16:12:44,304 INFO org.apache.hadoop.metrics2.impl.MetricsSystemImpl: Stopping N ...

  7. Python 网页爬虫

    解决问题:获取网页上的内容.特别是加载主框架后,再用AJAX获取数据生成内容的网页. PyQuery:可以像jQuery的py实现.你给他一个PyQuery一个HTML,他给你一个类似jQuery的操 ...

  8. JS验证框架(exValidation)

    exValidation是一个前台校验框架 能够校验前台的常用的输入错误. 例如,必须输入,用户输入长度...... ----------------------------------------- ...

  9. c++错误修复 数据库无法打开 无法右击 run outtiime

    先前有安装vs2015失败的前提 现象:1.无法右击  显示 explorer.exe   c++        run outtiime  这些字样 2. 安装有数据库的软件都不能用.显示数据库连接 ...

  10. iOS - OC & Xcode

    一.入门 1.1 iOS模版介绍 1.2 简单工程项目 1.3 设置App启动的设备方向 1.4 Xcode界面介绍 1.5 快速查找文件 1.6 快速更改同名变量 1.7 将代码提取为方法 1.8 ...