表空间是数据库的逻辑划分,一个表空间仅仅能属于一个数据库。

全部的数据库对象都存放在建立指定的表空间中。但主要存放的是表, 所以称作表空间。在oracle 数据库中至少存在一个表空间。即SYSTEM的表空间。一个表空间能够包括多个段。以及区。以及最小的块,同一时候也能够包括多个数据文件(物理结构)。

oracle 能够依据表空间对相关的用户配额以及磁盘空间都有极大的保护作用,并且还能够灵活的存放。同一时候也能够把不同的数据文件分开存放,保证不同数据文件的安全行。

所以在一般数据创建后,就会创建相关的表空间,再创建相关的用户。

Oracle数据库开创性地提出了表空间的设计理念,这为Oracle数据库的高性能做出了不可磨灭的贡献。能够这么说,Oracle中非常多优化都是基于表空间的设计理念而实现的。



下面针对数据表空间一些相关命令进行汇总

1,表空间汇总

--创建表空间的脚本

CREATE TABLESPACE TEST_FILE

LOGGING

DATAFILE '/U02/APP/ORACLE/ORADATA/ITSDB/TEST_FILE.DBF'

SIZE 10M  

AUTOEXTEND ON  

NEXT 10M MAXSIZE 10240M  

EXTENT MANAGEMENT LOCAL;



--查看用户的默认表空间

SELECT T.USERNAME,T.DEFAULT_TABLESPACE FROM DBA_USERS  T



--改动用户的默认表空间TABLESPACE_B

ALTER   USER   USER_A   DEFAULT   TABLESPACE   TABLESPACE_B



--用户在表空间上放开限制

ALTER   USER   USER_A   QUOTA   UNLIMITED   ON   TABLESPACE_B;  



--回收权限

REVOKE   UNLIMITED   TABLESPACE   ON   TABLESPACE_A   FROM   USER_A



--以使USER_A帐户不能在TABLESPACE_A上创建不论什么对象。

ALTER   USER   USER_A   QUOTA   0   ON   TABLESPACE_A





--移动表的表空间

ALTER TABLE CQRM.CQ_FLIGHTS_SEATS_SEQUENCE MOVE TABLESPACE CQRM;COMMIT;



--批量移动表空间的语句

SELECT 'ALTER TABLE '||TABLE_NAME||' MOVE TABLESPACE CQRM;COMMIT;' FROM USER_TABLES WHERE TABLESPACE_NAME='TEST';



--在表空间上重建索引

SELECT 'ALTER INDEX '||OWNER||'.'||INDEX_NAME||' REBUILD TABLESPACE CQRM;COMMIT;' FROM DBA_INDEXES WHERE  TABLE_NAME IN ('')

AND OWNER='TEST'





SELECT 'ALTER TABLE '||OWNER||'.'||TABLE_NAME||' MOVE TABLESPACE TEST;COMMIT;' FROM DBA_TABLES WHERE TABLESPACE_NAME='TEST1' AND OWNER='TEST'



2,改变表空间状态



1.使表空间脱机



ALTER TABLESPACE GAME OFFLINE;



假设是意外删除了数据文件,则必须带有RECOVER选项



ALTER TABLESPACE GAME OFFLINE FOR RECOVER;



2.使表空间联机



ALTER TABLESPACE GAME ONLINE;



3.使数据文件脱机



ALTER DATABASE DATAFILE 3 OFFLINE;



4.使数据文件联机



ALTER DATABASE DATAFILE 3 ONLINE;



5.使表空间仅仅读



ALTER TABLESPACE GAME READ ONLY;



6.使表空间可读写



ALTER TABLESPACE GAME READ WRITE;



删除表空间



DROP TABLESPACE DATA01 INCLUDING CONTENTS AND DATAFILES;



扩展表空间



3,首先查看表空间的名字和所属文件



SELECT TABLESPACE_NAME, FILE_ID, FILE_NAME,

ROUND(BYTES/(1024*1024),0) TOTAL_SPACE

FROM DBA_DATA_FILES

ORDER BY TABLESPACE_NAME;



1.添加数据文件

ALTER TABLESPACE GAME

ADD DATAFILE '/ORACLE/ORADATA/DB/GAME02.DBF' SIZE 1000M;



2.手动添加数据文件尺寸

ALTER DATABASE DATAFILE '/ORACLE/ORADATA/DB/GAME.DBF'

RESIZE 4000M;



3.设定数据文件自己主动扩展

ALTER DATABASE DATAFILE '/ORACLE/ORADATA/DB/GAME.DBF'

AUTOEXTEND ON NEXT 100M

MAXSIZE 10000M;

4.更改数据文件的位置

ALTER TABLESPACE APP_DATA RENAME DATAFILE  

'' TO ''





--整合表空间的碎片

ALTER TABLESPACE TABLESPACENAME COALESCE

此语句是整合表空间的碎片添加表空间的连续性,可是他不会收缩一个文件的大小的。

设定后查看表空间信息



SELECT A.TABLESPACE_NAME,A.BYTES TOTAL,B.BYTES USED, C.BYTES FREE,

(B.BYTES*100)/A.BYTES "% USED",(C.BYTES*100)/A.BYTES "% FREE"

FROM SYS.SM$TS_AVAIL A,SYS.SM$TS_USED B,SYS.SM$TS_FREE C

WHERE A.TABLESPACE_NAME=B.TABLESPACE_NAME AND A.TABLESPACE_NAME=C.TABLESPACE_NAME;



--查看表空间使用状况



SELECT UPPER(F.TABLESPACE_NAME) "表空间名",

       D.TOT_GROOTTE_MB "表空间大小(G)",

       D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(G)",

       CASE

         WHEN D.TOT_GROOTTE_MB = 0 THEN

          0

         ELSE

          TO_NUMBER(TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) /

                                  D.TOT_GROOTTE_MB * 100,

                                  2),

                            '990.99'))

       END "使用比",

       F.TOTAL_BYTES "空暇空间(G)",

       F.MAX_BYTES "最大块(G)"

  FROM (SELECT TABLESPACE_NAME,

               ROUND(SUM(BYTES) / (1024 * 1024 * 1024), 2) TOTAL_BYTES,

               ROUND(MAX(BYTES) / (1024 * 1024 * 1024), 2) MAX_BYTES

          FROM SYS.DBA_FREE_SPACE

         GROUP BY TABLESPACE_NAME) F,

       (SELECT DD.TABLESPACE_NAME,

               ROUND(SUM(DD.BYTES) / (1024 * 1024 * 1024), 2) TOT_GROOTTE_MB

          FROM SYS.DBA_DATA_FILES DD

         GROUP BY DD.TABLESPACE_NAME) D

 WHERE D.TABLESPACE_NAME = F.TABLESPACE_NAME

 ORDER BY 4 DESC

--也能够从视图DBA_TABLESPACE_USAGE_METRICS  查询假设表空间不是自己主动扩展则两者查询结果同样,假设是自己主动扩展的话则两者有偏差,以上面的查询为准





--查看用户使用了那些表空间

SELECT OWNER, OBJECT_TYPE, TABLESPACE_NAME

  FROM (SELECT DISTINCT 'TABLE' OBJECT_TYPE, OWNER, TABLESPACE_NAME

          FROM DBA_TABLES

        UNION

        SELECT DISTINCT 'INDEX' OBJECT_TYPE, OWNER, TABLESPACE_NAME

          FROM DBA_INDEXES)

 WHERE TABLESPACE_NAME IS NOT NULL

   AND OWNER = 'EZOFFICE'

 ORDER BY 1, 2, 3;

 

 

 SELECT T.SEGMENT_NAME, T.TABLESPACE_NAME, BYTES / 1024 / 1024

  FROM DBA_SEGMENTS T

 WHERE T.SEGMENT_NAME IN

       ('')

   AND OWNER = 'USER'



--能够查看回收的数据文件大小

SELECT 'ALTER DATABASE DATAFILE ''' || A.FILE_NAME || ''' RESIZE ' ||

       ROUND(A.FILESIZE - (A.FILESIZE - C.HWMSIZE - 100) * 0.8) || 'M;',

       A.FILESIZE || 'M' AS "数据文件的总大小",

       C.HWMSIZE || 'M' AS "数据文件的有用大小"

  FROM (SELECT FILE_ID, FILE_NAME, ROUND(BYTES / 1024 / 1024) AS FILESIZE

          FROM DBA_DATA_FILES) A,

       (SELECT FILE_ID, ROUND(MAX(BLOCK_ID) * 8 / 1024) AS HWMSIZE

          FROM DBA_EXTENTS

         GROUP BY FILE_ID) C

 WHERE A.FILE_ID = C.FILE_ID

AND A.FILESIZE - C.HWMSIZE > 100;

下一篇会继续讲述uodo表空间

oracle表空间查询维护命令大全之中的一个(数据表空间)史上最全的更多相关文章

  1. oracle表空间查询维护命令大全之二(undo表空间)

    --undo表空间汇总 --查看全部的表空间名字 select name from v$tablespace; --创建新的UNDO表空间,并设置自己主动扩展參数; create undo table ...

  2. oracle表空间查询维护命令大全之三(暂时表空间)史上最全

    --UNDO表空间汇总 --查看全部的表空间名字 SELECT NAME FROM V$TABLESPACE; --创建新的UNDO表空间,并设置自己主动扩展參数; CREATE UNDO TABLE ...

  3. ORACLE 查询一个数据表后通过遍历再插入另一个表中的两种写法

    ORACLE 查询一个数据表后通过遍历再插入另一个表中的两种写法 语法 第一种: 通过使用Oracle语句块  --指定文档所有部门都能查看 declare cursor TABLE_DEPT and ...

  4. 转载:Oracle RAC日常基本维护命令

    本文转载自: https://blog.csdn.net/tianlesoftware/article/details/5358573 Oracle RAC日常基本维护命令 好文转载, Oracle  ...

  5. Oracle 史上最全近百条Oracle DBA日常维护SQL脚本指令

    史上最全近百条Oracle DBA日常维护SQL脚本指令 https://mp.weixin.qq.com/s?__biz=MjM5MDAxOTk2MQ==&mid=2650281305&am ...

  6. 优秀后端架构师必会知识:史上最全MySQL大表优化方案总结

    本文原作者“ manong”,原创发表于segmentfault,原文链接:segmentfault.com/a/1190000006158186 1.引言   MySQL作为开源技术的代表作之一,是 ...

  7. [No00004F]史上最全Vim快捷键键位图(入门到进阶)vim常用命令总结

    在命令状态下对当前行用== (连按=两次), 或对多行用n==(n是自然数)表示自动缩进从当前行起的下面n行.你可以试试把代码缩进任意打乱再用n==排版,相当于一般IDE里的code format.使 ...

  8. 【2016年特别福利】史上最全CSS学习资料大全

    css学习篇 [2016年特别福利]史上最全CSS学习资料大全

  9. 史上最全最实用HBuilder快捷键大全

    史上最全最实用HBuilder快捷键大全 一.文件操作二.编辑操作三.插入操作四.转义操作五.选择操作六.跳转操作七.查找操作八.运行九.视图一.文件操作新建菜单: ctrl + N新建: ctrl ...

随机推荐

  1. VC error link

    错误1:LIBCD.lib(crt0.obj) : error LNK2001: unresolved external symbol _main在project-setting-link里找到pro ...

  2. 微信支付v2开发(7) 告警通知

    本文介绍微信支付中如何获得告警通知. 一.告警通知 为了及时通知商户异常,提高商户在微信平台的服务质量.微信后台会向商户推送告警通知,包括发货延迟.调用失败.通知失败等情况,通知的地址是商户在申请支付 ...

  3. 【2017 ACM-ICPC 亚洲区(乌鲁木齐赛区)网络赛 G】Query on a string

    [链接]h在这里写链接 [题意] 让你维护字符串的一段区间内T子串的个数. [题解] 因为t不大,所以. 暴力维护一下a[i]就好. a[i]表示的是S串从i位置开始,能和T串匹配几个字符. 用树状数 ...

  4. IOS总结

    1.Difference between shallow copy and deep copy?
浅复制和深复制的区别?
答案:浅层复制:只复制指向对象的指针,而不复制引用对象本身.
深层复制:复制引 ...

  5. C# 获取文件路径,读取项目中某程序集下文件

    获取文件路径 ------------------------------------------------------------------------- winform获取文件路径: stri ...

  6. c++读取lua配置基础类

    一.内容介绍 把lua作为配置文件,里面的参数值的获取,在他人基础上做了修改,并且补充了一维数组的处理方式. 若有不足之处请多多指教. 对于二维数组,没有成功.希望大家继续补充和修改,非常感谢! 二. ...

  7. IQueryFielter接口

    IQueryFilter基于属性查询过滤数据.需要定义一个where子句.可以指定要返回值的字段列表.如果没有指定列,将返回所有值.当需要根据属性值和属性的关系过滤数据时,使用该接口. 成员 AddF ...

  8. Eclipse RCP 中创建自己定义首选项,并能读取首选项中的值

    Eclipse RCP的插件中若想自定义首选项须要扩展扩展点: org.eclipse.core.runtime.preferences //该扩展点用于初始化首选项中的值 org.eclipse.u ...

  9. 【奇葩笔试】—— printf() 作为函数的参数及其返回值

    int f(int a, int b, int c){ return 0; } int main(int, char**){ f(printf("a"), printf(" ...

  10. Android中的消息机制:Handler消息传递机制 分类: H1_ANDROID 2013-10-27 22:54 1755人阅读 评论(0) 收藏

    参考<疯狂android讲义>第2版3.5 P214 一.背景 出于性能优化考虑,Android的UI操作并不是线程安全的,这意味着如果有多个线程并发操作UI组件,可能导致线程安全问题.为 ...