【总结】Oracle数据库 查看表空间和增加表空间
一、Oracle查看 表空间 的名称及其大小
查看 表空间的名称及其大小的SQL语句:
select t1.tablespace_name,round(sum(bytes/(1024*1024)),0) tablespace_Size_MB
from dba_tablespaces t1, dba_data_files t2
where t1.tablespace_name = t2.tablespace_name
group by t1.tablespace_name;
查询结果:
TABLESPACE_NAME TABLESPACE_SIZE_MB
------------------------------ ------------------
DLOTTEY 276480
SYSAUX 48450
UNDOTBS1 20000
INDEXMT 10240
USERS 1041
SYSTEM 10240
UNDOTBS2 20000
MMLOTTERY 215040 8 rows selected.
二、Oracle查看 表空间 的具体使用情况
方法1:(未排序)
select a.tablespace_name "tablespace_name",
totalspace "totalspaceM",
freespace "freespaceM",
round((1-freespace/totalspace)*100,2) "round%"
from
(select tablespace_name,round(sum(bytes)/1024/1024) totalspace from dba_data_files group by tablespace_name) a,
(select tablespace_name,round(sum(bytes)/1024/1024) freespace from dba_free_space group by tablespace_name) b
where a.tablespace_name=b.tablespace_name;
查询结果:
tablespace_name totalspaceM freespaceM round%
------------------------ ----------- ---------- ----------
DLOTTEY 276480 232415 15.94
SYSAUX 48450 9683 80.01
UNDOTBS1 20000 19741 1.3
INDEXMT 10240 10024 2.11
USERS 1041 138 86.74
SYSTEM 10240 4344 57.58
UNDOTBS2 20000 19601 2
MMLOTTERY 215040 36279 83.13 8 rows selected.
方法二:(查询结果排序)
select a.tablespace_name,
a.bytes/1024/1024 "Sum MB",
(a.bytes-b.bytes)/1024/1024 "used MB",
b.bytes/1024/1024 "free MB",
round(((a.bytes-b.bytes)/a.bytes)*100,2) "percent_used"
from
(select tablespace_name,sum(bytes) bytes from dba_data_files group by tablespace_name) a,
(select tablespace_name,sum(bytes) bytes,max(bytes) largest from dba_free_space group by tablespace_name) b
where a.tablespace_name=b.tablespace_name
order by ((a.bytes-b.bytes)/a.bytes) desc;
查询结果:
TABLESPACE_NAME Sum MB used MB free MB percent_used
---------------------- ---------- ---------- ---------- ------------
USERS 1041.25 903.375 137.875 86.76
MMLOTTERY 215040 178761 36279 83.13
SYSAUX 48450 38767 9683 80.01
SYSTEM 10240 5896.125 4343.875 57.58
DLOTTEY 276480 44065.4375 232414.563 15.94
INDEXMT 10240 215.625 10024.375 2.11
UNDOTBS2 20000 399.3125 19600.6875 2
UNDOTBS1 20000 257.5 19742.5 1.29 8 rows selected.
三、Oracle查看 表空间物理文件 的名称及大小
1、查询所有的表空间
select tablespace_name, file_id, file_name,
round(bytes/(1024*1024),0) total_space_MB
from dba_data_files
order by tablespace_name;
2、查询指定的表空间
select tablespace_name, file_id, file_name,
round(bytes/(1024*1024),0) total_space_MB
from dba_data_files
where tablespace_name = 'MMLOTTERY'
order by tablespace_name;
查询结果:
TABLESPACE_NAME FILE_ID FILE_NAME TOTAL_SPACE_MB
------------------- ---------- ------------------------------------------- --------------
MMLOTTERY 18 +DATA/ora11g/datafile/mmlottery01.dbf 30720
MMLOTTERY 19 +DATA/ora11g/datafile/mmlottery02.dbf 30720
MMLOTTERY 20 +DATA/ora11g/datafile/mmlottery03.dbf 30720
MMLOTTERY 22 +DATA/ora11g/datafile/mmlottery04.dbf 30720
MMLOTTERY 23 +DATA/ora11g/datafile/mmlottery05.dbf 30720
MMLOTTERY 26 +DATA/ora11g/datafile/mmlottery06.dbf 30720
MMLOTTERY 27 +DATA/ora11g/datafile/mmlottery07.dbf 30720 7 rows selected.
四、Oracle查看 表 真实占用的空间
SQL语句:
select t.owner,t.segment_name,t.segment_type,
sum(t.bytes/1024/1024) used_MB
from dba_segments t
where owner = 'MMLOTTERY'
group by owner,segment_name,segment_type
order by used_MB desc;
查询结果:
OWNER SEGMENT_NAME SEGMENT_TYPE USED_MB
------------------- -------------------------------- ------------------ ----------
MMLOTTERY TB_ORIGINAL_ORDERDETAILS TABLE 1792
MMLOTTERY TB_LOTTERY_SALEDETAIL TABLE 1472
MMLOTTERY TB_LOTTERYSCHEMEINFO_ADD TABLE 1280
MMLOTTERY TEST_007 TABLE 1152
MMLOTTERY TB_ACCOUNT_OPERATE_DETAIL TABLE 808
MMLOTTERY PK14 INDEX 377
MMLOTTERY PK14_11 INDEX 312
MMLOTTERY PK14_13 INDEX 200
MMLOTTERY PK14_12 INDEX 160
MMLOTTERY TB_BONUS_ORDERDETAILS TABLE 160
MMLOTTERY TB_WINBONUS_DETAIL TABLE 144 11 rows selected.
五、Oracle 增加表空间
alter tablespace MMLOTTERY add datafile '+DATA/ora11g/datafile/mmlottery08.dbf' size 30720m autoextend on next 200m;
注意:如果添加表空间的文件名重复,那么会报错,如下:
SQL> alter tablespace MMLOTTERY add datafile '+DATA/ora11g/datafile/mmlottery08.dbf' size 30720m autoextend on next 200m;
alter tablespace MMLOTTERY add datafile '+DATA/ora11g/datafile/mmlottery08.dbf' size 30720m autoextend on next 200m
*
ERROR at line 1:
ORA-01537: cannot add file '+DATA/ora11g/datafile/mmlottery08.dbf' - file already part of database
六、Oracle 临时表空间的查看与增加
TABLESPACE_NAME FILE_ID FILE_NAME TEMP_SIZE_MB
----------------- ---------- --------------------------------------------- ------------
TEMP 1 +DATA/ora11g/tempfile/temp.262.917714589 20000
七、查看表空间是否为自增
表空间是有数据文件组成的,所以看表空间是否自增即看数据文件,如下查自增的表空间:
select tablespace_name,file_name,autoextensible from dba_data_files where autoextensible='YES';
autoextensible: YES/NO 即表示是否自增。
示例:
SQL> select tablespace_name,file_name,autoextensible from dba_data_files where TABLESPACE_NAME='USERS'; TABLESPACE_NAME FILE_NAME AUT
-------------------- ------------------------------------------------------------ ---
USERS +DATA/ora11g/datafile/users.264.917714693 YES
【实例】Oracle 表空间的查看与增加
步骤 1、查看表空间的具体使用情况
SQL语句,如下:
select a.tablespace_name,
a.bytes/1024/1024 "Sum MB",
(a.bytes-b.bytes)/1024/1024 "used MB",
b.bytes/1024/1024 "free MB",
round(((a.bytes-b.bytes)/a.bytes)*100,2) "percent_used"
from
(select tablespace_name,sum(bytes) bytes from dba_data_files group by tablespace_name) a,
(select tablespace_name,sum(bytes) bytes,max(bytes) largest from dba_free_space group by tablespace_name) b
where a.tablespace_name=b.tablespace_name
order by ((a.bytes-b.bytes)/a.bytes) desc;
查询结果:
TABLESPACE_NAME Sum MB used MB free MB percent_used
---------------------- ---------- ---------- ---------- ------------
USERS 1041.25 903.375 137.875 86.76
MMLOTTERY 215040 178761 36279 83.13
SYSAUX 48450 38767 9683 80.01
SYSTEM 10240 5896.125 4343.875 57.58
DLOTTEY 276480 44065.4375 232414.563 15.94
INDEXMT 10240 215.625 10024.375 2.11
UNDOTBS2 20000 399.3125 19600.6875 2
UNDOTBS1 20000 257.5 19742.5 1.29 8 rows selected.
步骤2、查看指定表空间(MMLOTTERY)的物理文件名称及其大小
select tablespace_name, file_id, file_name,
round(bytes/(1024*1024),0) total_space_MB
from dba_data_files
where tablespace_name = 'MMLOTTERY'
order by tablespace_name;
查询结果:
TABLESPACE_NAME FILE_ID FILE_NAME TOTAL_SPACE_MB
------------------- ---------- ------------------------------------------- --------------
MMLOTTERY 18 +DATA/ora11g/datafile/mmlottery01.dbf 30720
MMLOTTERY 19 +DATA/ora11g/datafile/mmlottery02.dbf 30720
MMLOTTERY 20 +DATA/ora11g/datafile/mmlottery03.dbf 30720
MMLOTTERY 22 +DATA/ora11g/datafile/mmlottery04.dbf 30720
MMLOTTERY 23 +DATA/ora11g/datafile/mmlottery05.dbf 30720
MMLOTTERY 26 +DATA/ora11g/datafile/mmlottery06.dbf 30720
MMLOTTERY 27 +DATA/ora11g/datafile/mmlottery07.dbf 30720 7 rows selected.
步骤3、增加指定表空间(MMLOTTERY)的大小
增加指定表空间的大小,SQL语句:
SQL> alter tablespace MMLOTTERY add datafile '+DATA/ora11g/datafile/mmlottery.dbf' size 30720m; Tablespace altered.
根据步骤2的命令,查询增加后的结果:
TABLESPACE_NAME FILE_ID FILE_NAME TOTAL_SPACE_MB
-------------------- ---------- ------------------------------------------------------------ --------------
MMLOTTERY 18 +DATA/ora11g/datafile/mmlottery01.dbf 30720
MMLOTTERY 19 +DATA/ora11g/datafile/mmlottery02.dbf 30720
MMLOTTERY 20 +DATA/ora11g/datafile/mmlottery03.dbf 30720
MMLOTTERY 22 +DATA/ora11g/datafile/mmlottery04.dbf 30720
MMLOTTERY 23 +DATA/ora11g/datafile/mmlottery05.dbf 30720
MMLOTTERY 26 +DATA/ora11g/datafile/mmlottery06.dbf 30720
MMLOTTERY 27 +DATA/ora11g/datafile/mmlottery07.dbf 30720
MMLOTTERY 28 +DATA/ora11g/datafile/mmlottery08.dbf 30720 8 rows selected.
步骤4、查看增加表空间后的具体情况
SQL语句:
select a.tablespace_name,
a.bytes/1024/1024 "Sum MB",
(a.bytes-b.bytes)/1024/1024 "used MB",
b.bytes/1024/1024 "free MB",
round(((a.bytes-b.bytes)/a.bytes)*100,2) "percent_used"
from
(select tablespace_name,sum(bytes) bytes from dba_data_files group by tablespace_name) a,
(select tablespace_name,sum(bytes) bytes,max(bytes) largest from dba_free_space group by tablespace_name) b
where a.tablespace_name=b.tablespace_name
and a.tablespace_name='MMLOTTERY';
查询结果:
TABLESPACE_NAME Sum MB used MB free MB percent_used
-------------------- ---------- ---------- ---------- ------------
MMLOTTERY 245760 179218 66542 72.92
【备注】
select * from tablename where rownum = 1;
alter user user_name default tablespace dev_tb;
alter user user_name temporary tablespace dev_temp;
select t.file_name,t1.owner,t1.segment_name,t1.segment_type,t1.tablespace_name from dba_data_files t,dba_extents t1 where t.file_id=t1.file_id and file_name='你要查询的数据文件路径';
【总结】Oracle数据库 查看表空间和增加表空间的更多相关文章
- 使用oracle数据库,多用户同时对一个表进行增加,删除,修改,查看等操作,会不会有影响?
使用oracle数据库,多用户同时对一个表进行增加,删除,修改,查看等操作,会不会有影响? 1.问题:各操作间或者性能上会不会有影响? 如果有该如何解决? 多用户操作的影响主要是回锁定记录,oracl ...
- Oracle数据库查看表空间sql语句
转: Oracle数据库查看表空间sql语句 2018-09-03 15:49:51 兰海泽 阅读数 6212 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出 ...
- 基础概念:Oracle数据库、实例、用户、表空间、表之间的关系
基础概念:Oracle数据库.实例.用户.表空间.表之间的关系 数据库: Oracle数据库是数据的物理存储.这就包括(数据文件ORA或者DBF.控制文件.联机日志.参数文件).其实Oracle数据库 ...
- oracle数据库_实例_用户_表空间之间的关系
基础概念:Oracle数据库.实例.用户.表空间.表之间的关系 数据库:Oracle数据库是数据的物理存储.这就包括(数据文件ORA或者DBF.控制文件.联机日志.参数文件).其实Oracle数据库的 ...
- Oracle数据库访问其他用户下的表,不加表所属的用户名的实现方法
一. 问题: 如何实现在Oracle数据库中访问其他用户的表时不需加表所属的用户名 二. 举例: Oracle里面的用户A,要访问用户B的表需要带用户B的前缀,如访问用户B的 TEST表,需要这样访问 ...
- Oracle数据库、实例、用户、表空间、表之间的关系
完整的Oracle数据库通常由两部分组成:Oracle数据库和数据库实例. 1) 数据库是一系列物理文件的集合(数据文件,控制文件,联机日志,参数文件等): 2) Oracle数据库实例则是一组Ora ...
- oracle数据库_实例_用户_表空间之间的关系(转)
数据库:Oracle数据库是数据的物理存储.这就包括(数据文件ORA或者DBF.控制文件.联机日志.参数文件).其实Oracle数据库的概念和其它数据库不一样,这里的数据库是一个操作系统只有一个库.可 ...
- Oracle 数据库、实例、用户、表空间、表之间的关系
数据库: Oracle数据库是数据的物理存储.这就包括(数据文件ORA或者DBF.控制文件.联机日志.参数文件).其实oracle数据库的概念和其它数据库不一样,这里的数据库是一个操作系统只有一个库. ...
- DB2查看表空间和增加表空间容量
Db2 connect to xxx Db2 “LIST TABLESPACES SHOW DETAIL” Tablespace ID = 7 Name = TSASNAA Type = Databa ...
随机推荐
- 3D坐标系
在3D渲染中,首先要确定的就是坐标系,坐标系根据实际情况,分为两种: 左手坐标系 右手坐标系 在3D空间中,这两个坐标系是没有办法重合到一起的: Unity使用的坐标系为左手坐标系. 在确定左手坐标系 ...
- SICP 习题1.10
题目要求 解题方法 递归计算 没什么好说的,单纯的套用数学公示 (define (f n) (if (< n 3) n (+ (f (- n 1)) (* 2 (f (- n 2))) (* 3 ...
- Jmeter 断言-检查点
1. http请求/添加/断言/响应断言 2. 输入一个返回数据里没有的参数 3.果然报错了 断言的作用是用来查看接口文档里是否有自己想要的数据!
- Mysql慢查询(分析工具)
慢查询分析工具[mysqldumpslow] 常用的慢查询日志分析工具 汇总除查询条件外其他完全相同的SQL,并将分析结果按照参数中所指定的顺序输出 语法: mysqldumpslow -s r -t ...
- JavaScript五中迭代方法小解
ECMAScript 为数组定义了五个迭代方法.每个方法都接收两个参数:要在每一项上运行的函数和(可选的)运行该函数的作用域对象——影响this的值.传入这些方法中的函数会接收三个参数:数组项的值.该 ...
- windows软件介绍
基础软件 txt 阅读 NotePad++,方便阅读代码,支持列复制. 全局搜索 Everything 截图 Snipaste 读取图片 Picase.PureRef 其他 置顶窗口 DeskPins ...
- taro-script 0.4 发布,基于Taro v3的js解释器组件
taro-script Github地址 基于Taro v3开发,支持多端小程序动态加载远程 JavaScript 脚本并执行,支持 ES5 语法 最近更新内容 新增useScriptContext获 ...
- linux系统漏洞扫描工具lynis
lynis 是一款运行在 Unix/Linux 平台上的基于主机的.开源的安全审计软件.Lynis是针对Unix/Linux的安全检查工具,可以发现潜在的安全威胁.这个工具覆盖可疑文件监测.漏洞.恶意 ...
- Tomcat 第一篇:源码导入 IDEA 编辑器
1 引言 做 Java 的同学应该都见过上面这只名字叫 Tomcat 的猫,毕竟这只猫在过去和现在都是全球最流行的 Web 容器之一. 很有意思的一件事儿是从我接触这只猫开始,从来不知道它的中文名字是 ...
- [剑指Offer]18-题目一:删除链表的节点 题目二:删除链表中重复节点
题目一 题目 O(1)时间复杂度删除给定链表节点. 题解 用待删除节点后一个节点的值覆盖待删除节点值,更新链接关系. 注意链表只有一个节点:删除尾结点:删除头节点的处理. 代码 class ListN ...