天天看點

Oracle管理表空間和資料檔案

Oracle管理表空間和資料檔案

文章目錄

  • ​​前言​​
  • ​​1. 建立資料表空間​​
  • ​​2.使用資料表空間​​
  • ​​3.改變表空間的狀态​​
  • ​​4.删除表空間​​
  • ​​5.擴充表空間​​
  • ​​6.移動資料檔案​​

前言

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='表空間名';