Oracle管理表空间和数据文件

125 篇文章 109 订阅
作者:IT邦德
中国DBA联盟(ACDU)成员,目前从事DBA及程序编程
(Web\java\Python)工作,主要服务于生产制造
现拥有 Oracle 11g  OCP/OCM、
Mysql、Oceanbase(OBCA)认证
分布式TBase\TDSQL数据库、国产达梦数据库以及红帽子认证
从业8年DBA工作,在数据库领域有丰富的经验
B站主播Oracle、Mysql、PG实战课程,请搜索:jeames007

擅长Oracle数据库运维开发,备份恢复,安装迁移,性能优化、故障应急处理等。

在这里插入图片描述

前言

本文总结了Oracle常用管理表空间和数据文件的命令,大家多点赞关注!

1. 建立数据表空间

SQL>create tablespace data01 datafile 'f:\data01.dbf' size 20m uniform size 128k;

--生产使用命令
  CREATE TABLESPACE "jeames007" DATAFILE 
  'I:\ORACLE\PRODUCT\10.2.0\ORADATA\dab.01' SIZE 4194304000
  LOGGING ONLINE PERMANENT BLOCKSIZE 8192
  EXTENT MANAGEMENT LOCAL AUTOALLOCATE SEGMENT SPACE MANAGEMENT AUTO

2.使用数据表空间

SQL>create table mypart(deptno number(2),dname varchar2(14),loc varchar2(13)) tablespace data01;

3.改变表空间的状态

1)	使表空间脱机
SQL>alter tablespace 表空间名 offine;
2)使表空间连机
SQL>alter tablespace 表空间名 onine;
3)只读表空间
SQL>alter tablespace 表空间名 read only;
4)可读写表空间
SQL>alter tablespace data01 read write;
实例:
1)	知道表空间名,显示该表空间包括的所有表
SQL>select table_name from all_tables where tablespace_name='表空间名';
2)	知道表名,查看该表属于哪个表空间
SQL>select * from all_tables where table_name='表名';

4.删除表空间

SQL>drop tablespace 表空间including contents and datafiles;(彻底删除);

5.扩展表空间

1)	增加数据文件
SQL>alter tablespace data01 add datafile'f:\data02.dbf'size 30m;
2)	增加数据文件的大小
SQL>alter database datafile 'f:\data01.dbf' resize 50m;
3)	设置文件的自动增长
SQL>alter database datafile 'f:\data01.dbf'autoextend on next 10m maxsize 500m;

6.移动数据文件

1)	确定数据文件所在的表空间
SQL>select tablespace_name from dba_data_files 
where file_name='F:\DATA02.DBF';
2)	使表空间脱机(确保数据文件的一致性,把表空间转变为Offline状态)
SQL>alter tablespace data01 offline;
3)	使用命令移动数据文件到指定的目标位置(或者剪切)
SQL>host move f:\data02.dbf e:\data02.dbf;
4)	执行alter tablespace命令
SQL>alter tablespace data01 rename datafile 'f:\data02.dbf'to'e:\data02.dbf';
5)	使得表空间联机
SQL>alter tablespace data01 online;
补充:
1)	查询表空间使用情况
SQL>SELECT UPPER(F.TABLESPACE_NAME) "表空间名",
  D.TOT_GROOTTE_MB "表空间大小(M)",
  D.TOT_GROOTTE_MB - F.TOTAL_BYTES "已使用空间(M)",
  TO_CHAR(ROUND((D.TOT_GROOTTE_MB - F.TOTAL_BYTES) / D.TOT_GROOTTE_MB * 100,2),'990.99') || '%' "使用比",
  F.TOTAL_BYTES "空闲空间(M)",
  F.MAX_BYTES "最大块(M)"
  FROM (SELECT TABLESPACE_NAME,
  ROUND(SUM(BYTES) / (1024 * 1024), 2) TOTAL_BYTES,
  ROUND(MAX(BYTES) / (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), 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 1;
2)	查询表空间的总容量
SQL>select tablespace_name, sum(bytes) / 1024 / 1024 as MB
  from dba_data_files
  group by tablespace_name;
3)显示表空间所包含的数据文件
SQL>select file_name,bytes from dba_data_files where tablespace_name='表空间名';

如果觉得文章对你有帮助,点赞、收藏、关注、评论,一键四连支持
您的批评指正是我写作的最大动力!

❤️ 技术交流可以 关注公众号:IT邦德 ❤️

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT邦德

客户部署资料,步骤超详细

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值