设为首页 收藏本站
查看: 1202|回复: 0

[经验分享] oracle 数据库管理--管理表空间和数据文件

[复制链接]

尚未签到

发表于 2016-8-4 15:37:39 | 显示全部楼层 |阅读模式
  目前orcl数据库用sys as sysdba创建的表空间
  --创建表空间
  create tablespace NNC_DATA01 datafile 'C:\oracle\product\10.2.0\oradata\orcl\NNC_DATA01.dbf' size 500M autoextend on;
  --查看表空间
  select file_name,tablespace_name from dba_data_files order by file_name;
  --查询用户的默认表空间
  select user_id, username, default_tablespace from dba_users;
  --修改用户的默认表空间
  alter user epa_dev default tablespace NNC_DATA01;
  

查看oracle表空间已使用大小 


1. 查看所有表空间大小
SQL> select tablespace_name,sum(bytes)/1024/1024 from dba_data_files group by tablespace_name;
2. 已经使用的表空间大小
SQL> select tablespace_name,sum(bytes)/1024/1024 from dba_free_space group by tablespace_name;
3. 所以使用空间可以这样计算
select a.tablespace_name,total,free,total-free used from
( select tablespace_name,sum(bytes)/1024/1024 total from dba_data_files
group by tablespace_name) a,
( select tablespace_name,sum(bytes)/1024/1024 free from dba_free_space
group by tablespace_name) b
where a.tablespace_name=b.tablespace_name;
4. 下面这条语句查看所有segment的大小。
Select Segment_Name,Sum(bytes)/1024/1024 From User_Extents Group By Segment_Name
5. 还有在命令行情况下如何将结果放到一个文件里。
SQL> spool out.txt
SQL> select * from v$database;
SQL> spool off
  

oracle users01.dbf 越来越大

oracle删除数据后,表空间不释放,dbf文件越来越大,可以使用:
 
SQL> ALTER DATABASE DATAFILE 'C:\oracle\product\10.2.0\oradata\orcl\USERS01.DBF' RESIZE 1G;
来缩小表空间,如果报错:“ORA-03297: 文件包含在请求的 RESIZE 值以外使用的数据”,说明1G不够,可以加大RESIZE值。
 
查看Oracle User所有对象占用的空间大小:
使用DBA_Extents,DBA_Segments(有DBA权限User登录)或者使用某个User登录后使用user_extents,user_segments查询当前User所有对象占用空间大小。
下面2个Sql得到的结果一样:
select sum(bytes)/1024/1024||'M' from user_segments;
select sum(bytes)/1024/1024||'M' from user_extents;
  
  转:http://www.cnblogs.com/linjiqin/archive/2012/02/16/2354328.html
一、概念
表空间是数据库的逻辑组成部分。
从物理上讲,数据库数据存放在数据文件中;
从逻辑上讲,数据库数据则是存放在表空间中,表空间由一个或多个数据文件组成。

            
二、数据库的逻辑结构
oracle中逻辑结构包括表空间、段、区和块。
说明一下数据库由表空间构成,而表空间又是由段构成,而段又是由区构成,而区又是由oracle块构成的这样的一种结构,可以提高数据库的效率。

           
三、表空间
1、概念
表空间用于从逻辑上组织数据库的数据。数据库逻辑上是由一个或是多个表空间组成的。通过表空间可以达到以下作用:
1)、控制数据库占用的磁盘空间
2)、dba可以将不同数据类型部署到不同的位置,这样有利于提高i/o性能,同时利于备份和恢复等管理操作。

             
2、建立表空间
建立表空间是使用crate tablespace命令完成的,需要注意的是,一般情况下,建立表空间是特权用户或是dba来执行的,如果用其它用户来创建表空间,则用户必须要具有create tablespace的系统权限。
1)、建立数据表空间
在建立数据库后,为便于管理表,最好建立自己的表空间
--路径D:\dev\oracle\product\10.2.0\要存在,否则创建不成功
create tablespace data01 datafile 'D:\dev\oracle\product\10.2.0\dada01.dbf' size 20m uniform size 128k; 
说明:执行完上述命令后,会建立名称为data01的表空间,并为该表空间建立名称为data01.dbf的数据文件,区的大小为128k
2)、使用数据表空间
create table mypart(
   deptno number(4), 
   dname varchar2(14), 
   loc varchar2(13)
) tablespace data01;

3、改变表空间的状态
当建立表空间时,表空间处于联机的(online)状态,此时该表空间是可以访问的,并且该表空间是可以读写的,即可以查询该表空间的数据,而且还可以在表空间执行各种语句。但是在进行系统维护或是数据维护时,可能需要改变表空间的状态。一般情况下,由特权用户或是dba来操作。
1)、使表空间脱机
alter tablespace 表空间名 offline;
eg、alter tablespace data01 offline;--表空间名不能加单引号
2)、使表空间联机
alter tablespace 表空间名 online;
eg、alter tablespace data01 online;
3)、只读表空间
当建立表空间时,表空间可以读写,如果不希望在该表空间上执行update,delete,insert操作,那么可以将表空间修改为只读
alter tablespace 表空间名 read only;
注意:修改为可写是alter tablespace 表空间名 read write;)

我们给大家举一个实例,说明只读特性:
1)、知道表空间名,显示该表空间包括的所有表
select * from all_tables where tablespace_name=’表空间名’;
eg、select * from all_tables where tablespace_name='DATA01'; --DATA01要大写格式
2)、 知道表名,查看该表属于那个表空间
select tablespace_name, table_name from user_tables where table_name='EMP';
通过2我们可以知道scott.emp是在system这个表空间上,现在我们可以将system改为只读的但是我们不会成功,因为system是系统表空间,如果是普通表空间,那么我们就可以将其设为只读的,给大家做一个演示,可以加强理解。
3)、
4)、使表空间可读写
alter tablespace 表空间名 read write;

           
4、删除表空间
一般情况下,由特权用户或是dba来操作,如果是其它用户操作,那么要求用户具有drop tablespace 系统权限。
drop tablespace ‘表空间’ including contents and datafiles;
eg、drop TABLESPACE DATA01 including contents and datafiles;
说明:including contents表示删除表空间时,删除该空间的所有数据库对象,而datafiles表示将数据库文件也删除。

              
5、扩展表空间
表空间是由数据文件组成的,表空间的大小实际上就是数据文件相加后的大小。那么我们可以想象,假定表employee存放到data01表空间上,初始大小就是2M,当数据满2M空间后,如果在向employee表插入数据,这样就会显示空间不足的错误。
案例说明:
1. 建立一个表空间sp01
eg、create tablespace sp01 datafile 'D:\dev\oracle\product\10.2.0\dada01.dbf' size 1m uniform size 128k; 
2. 在该表空间上建立一个普通表mydment其结构和dept一样
create table mypart(
   deptno number(4), 
   dname varchar2(14), 
   loc varchar2(13)
) tablespace sp01;
3. 向该表中加入数据insert into mydment select * from dept;
4. 当一定时候就会出现无法扩展的问题,怎么办?
5. 就扩展该表空间,为其增加更多的存储空间。
有三种方法:
1. 增加数据文件
SQL> alter tablespace sp01 add datafile 'D:\dev\oracle\product\10.2.0\dada02.dbf' size 1m;
2. 修改数据文件的大小
SQL> alter tablespace sp01 'D:\dev\oracle\product\10.2.0\dada01.dbf' resize 4m;
这里需要注意的是数据文件的大小不要超过500m。
3. 设置文件的自动增长。
SQL> alter tablespace sp01 'D:\dev\oracle\product\10.2.0\dada01.dbf' autoextend on next 10m maxsize 500m;

             
6、移动数据文件
有时,如果你的数据文件所在的磁盘损坏时,该数据文件将不能再使用,为了能够重新使用,需要将这些文件的副本移动到其它的磁盘,然后恢复。
下面以移动数据文件sp01.dbf为例来说明:
1. 确定数据文件所在的表空间
select tablespace_name from dba_data_files where file_name=upper('D:\dev\oracle\product\10.2.0\dada01.dbf');
2. 使表空间脱机
--确保数据文件的一致性,将表空间转变为offline的状态。
alter tablespace sp01 offline;
3. 使用命令移动数据文件到指定的目标位置
host move D:\dev\oracle\product\10.2.0\dada01.dbf c:\dada01.dbf;

4. 执行alter tablespace 命令
在物理上移动了数据后,还必须执行alter tablespace命令对数据库文件进行逻辑修改:
alter tablespace sp01 rename datafile 'D:\dev\oracle\product\10.2.0\dada01.dbf' to 'c:\sp01.dbf';
5. 使得表空间联机
在移动了数据文件后,为了使用户可以访问该表空间,必须将其转变为online状态。
alter tablespace sp01 online;

             
7、显示表空间信息
查询数据字典视图dba_tablespaces,显示表空间的信息:
select tablespace_name from dba_tablespaces;
显示表空间所包含的数据文件
查询数据字典视图dba_data_files,可显示表空间所包含的数据文件,如下:
select file_name, bytes from dba_data_files where tablespace_name='表空间';

        
四、表空间小结
1. 了解表空间和数据文件的作用
2. 掌握常用表空间,undo表空间和临时表空间的建立方法
3. 了解表空间的各个状态(online, offline, read write, read only)的作用,及如何改变表空间的状态的方法。
4. 了解移动数据文件的原因,及使用alter tablespace 和alter datatable命令移动数据文件的方法。

               
五、其它表空间
除了最常用的数据表空间外,还有其它类型表空间:
1. 索引表空间
2. undo表空间
3. 临时表空间
4. 非标准块的表空间
这几种表空间,大家伙可以自己参考书籍研究,这里我就不讲。

 
 
*****************************
转:http://database.iyunv.com/art/200910/158936.htm
1、先查询空闲空间


  • select tablespace_name,file_id,block_id,bytes,blocks from dba_free_space; 

2、增加Oracle表空间
先查询数据文件名称、大小和路径的信息,语句如下:


  • select tablespace_name,file_id,bytes,file_name from dba_data_files; 

3、修改文件大小语句如下


  • alter database datafile   
  • '需要增加的数据文件路径,即上面查询出来的路径  
  • 'resize 800M; 

4、创建Oracle表空间


  • create tablespace test  
  • datafile '/home/app/oracle/oradata/oracle8i/test01.dbf' size 8M  
  • autoextend on  
  • next 5M  
  • maxsize 10M;  
  •  
  • create tablespace sales  
  • datafile '/home/app/oracle/oradata/oracle8i/sales01.dbf' size 800M  
  • autoextend on  
  • next 50M  
  • maxsize unlimited  
  • maxsize unlimited 是大小不受限制  
  •  
  • create tablespace sales  
  • datafile '/home/app/oracle/oradata/oracle8i/sales01.dbf' size 800M  
  • autoextend on  
  • next 50M  
  • maxsize 1000M  
  • extent management local uniform;  
  • unform表示区的大小相同,默认为1M  
  •  
  • create tablespace sales  
  • datafile '/home/app/oracle/oradata/oracle8i/sales01.dbf' size 800M  
  • autoextend on  
  • next 50M  
  • maxsize 1000M  
  • extent management local uniform size 500K;  
  • unform size 500K表示区的大小相同,为500K  
  •  
  • create tablespace sales  
  • datafile '/home/app/oracle/oradata/oracle8i/sales01.dbf' size 800M  
  • autoextend on  
  • next 50M  
  • maxsize 1000M  
  • extent management local autoallocate;  
  • autoallocate表示区的大小由随表的大小自动动态改变,大表使用大区小表使用小区  
  •  
  • create tablespace sales  
  • datafile '/home/app/oracle/oradata/oracle8i/sales01.dbf' size 800M  
  • autoextend on  
  • next 50M  
  • maxsize 1000M  
  • temporary;  
  • temporary创建字典管理临时表空间  
  •  
  • create temporary tablespace sales  
  • tempfile '/home/app/oracle/oradata/oracle8i/sales01.dbf' size 800M  
  • autoextend on  
  • next 50M  
  • maxsize 1000M  
  • 创建本地管理临时表空间,如果是临时表空间,所有语句中的datafile都换为tempfile  
  •  
  • 8i系统默认创建字典管理临时表空间,要创建本地管理临时表空间要加temporary tablespace关键字  
  • 创建本地管理临时表空间时,不得使用atuoallocate参数,系统默认创建uniform管理方式  
  •  
  • 为表空间增加数据文件:  
  • alter tablespace sales add  
  • datafile '/home/app/oracle/oradata/oracle8i/sales02.dbf' size 800M  
  • autoextend on next 50M  
  • maxsize 1000M; 

创建本地管理临时Oracle表空间,如果是临时表空间,所有语句中的datafile都换为tempfile8i系统默认创建字典管理临时表空间,要创建本地管理临时表空间要加temporary tablespace关键字创建本地管理临时表空间时,不得使用atuoallocate参数,系统默认创建uniform管理方式
为表空间增加数据文件:


  • alter tablespace sales add  
  • datafile '/home/app/oracle/oradata/oracle8i/sales02.dbf' size 800M  
  • autoextend on next 50M  
  • maxsize 1000M; 

5、更改自动扩展属性:


  • alter database datafile  
  • '/home/app/oracle/oradata/oracle8i/sales01.dbf',  
  • '/home/app/oracle/oradata/oracle8i/sales02.dbf'  
  • '/home/app/oracle/oradata/oracle8i/sales01.dbf  
  • autoextend off; 

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-252899-1-1.html 上篇帖子: oracle 重做日志组的三个状态 下篇帖子: oracle 11G 字符集筹码的问题解决
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表