Oracle基础(三) 表空间
数据库的存储结构
数据库主要用于存储和检索相关的信息,Oracle数据库包含逻辑结构和物理结构。
物理结构是指现实存储单元,由一组文件组成如数据文件、日志文件、控制文件。
数据文件:用于存储数据的文件。如表,索引和数据等都存储在数据文件中。
日志文件:用于记录对数据库的修改信息。
控制文件:用于存储 Oracle实例信息、数据文件信息和日志文件信息的二进制文件。由于存储了数据文件和日志文件的信息,所以 Oracle启动时必须访问呢控制文件。
逻辑结构式是指数据概念性的组织。包括 表空间、表、行等概念组成。
一、表空间(tablespace)的概念
表空间是Oracle特殊的发明,用于存储数据库表,索引等对象的磁盘逻辑空间。在物理上表空间由1个或者多个数据文件组成,而数据库在逻辑上由1个或者多个表空间组成。
表空间在Oracle10g中北分为一下3类:
1、永久性表空间:一般保持基表、视图、存储过程和索引等数据。SYSTEM、SYSAUX、USERS、EXAMPLE表空间是默认安装的。
2、临时性表空间:用于保存系统中短期活动的数据,如排序数据等。
3、撤销表空间;用来帮助回退未提交的事务数据,已提交了的数据在这里是不可以恢复的。
一般不需要建立临时表空间和撤销表空间,除非把它们转移到其他磁盘以提高性能。
表空间的目的:
1、对不同用户分配不同的表空间,对不同的模式对象分配不同的表空间,方便对用户操作,对模式对象的管理。
2、可以将不同数据文件创建到不同的磁盘中,有利于管理磁盘空间,有利于提高I/O性能,有利于备份和恢复数据等。
二、系统自带的表空间:
SYSTEM表空间:用于存放Oracle系统内部表和数据字典的数据,如表名、列名、用户名等。不建议将用户创建的表、索引等对象存放到SYSTEM表空间中。
SYSAUS表空间:用于存放Oracle系统内部的常用的样例用户的对象。SYSAUX表空间一般不存储用户的数据,由Oracle系统自动维护。
Undotbs表空间:Undotbs表空间用于存放撤销信息的表空间。当我们对数据库表的数据进行增加、修改、删除时,Oracle自动使用撤销表空间来临时存储修改前的数据。当所做操作提交后, Oracle可根据需要保留修改前数据的时间长短来释放撤销表空间的部分空间。一般在创建Oracle实例后,Oracle会自动创建一个名为UNDOTBS1的撤销表空间。
TEMP表空间:用于存放临时数据的特殊表空间。例如:当用户需要进行排序时,Oracle讲排序的数据临时放到该表空间内。排序完成后即可释放排序数据所占用的空间。
USERS表空间:Users表空间是Oracle建议用户使用的表空间,可以在这个表空间上创建各种对象,如创建表、索引等。
Example表空间:(实例表空间)它用来存放我们安装Oracle的时候创建的实例用户模式的数据信息。
除了 Oracle自带的表空间外,用户可以根据需要创建多个表空间,以区分用户数据和系统数据。一般在Oracle数据库中,只创建一个数据库实例,而创建多个表空间来管理保存多个项目中的数据库表。
三、创建表空间
语法:
CREATE TABLESPACE tablespacename
DATAFILE 'filename'[size integer]
[AUTOEXTEND[OFF|ON]]
tablespancename:表示创建表空间的名称。
filename:表示组成表空间的一个活多个数据文件,当有多个数据文件时,使用,分隔。
size:指定文件的大小,单位是K(字节)或者M(兆)。
AUTOEXTEND:用来启用或警用数据文件的自动扩展,只有设置了AUTOEXTEND后,在存储空间使用完毕后才会自动扩展,设置为ON即可,如果设置为OFF,则不能自动扩展。会导致存储空间不足的情况。
示例:
--创建一个表空间,物理文件为shop_dev_data.dbf,初始大小为100M,为自动增长
CREATE TABLESPACE shop_dev_data
datafile 'E:\DB\Shop\shop_dev_data.dbf'
size 100m autoextend on
四、操作表空间
1、更改表空间大小:
ALTER DATABASE DATAFILE '数据文件路径' resize <新的大小>
--将表空间的物理文件大小设置为50M
ALTER DATABASE DATAFILE 'E:\DB\Shop\shop_dev_data.dbf' resize 50m
2、改变表空间的属性和状态
ALTER TABLESPACE <表空间名称> READ WRITE;
--设置表空间为只读状态
ALTER TABLESPACE SHOP_DEV_DATA READ ONLY; --设置表空间为读写状态
ALTER TABLESPACE SHOP_DEV_DATA READ WRITE; --修改表空间状态为offline;
ALTER TABLESPACE SHOP_DEV_DATA OFFLINE;
3、删除表空间
DROP TABLESPACE tablespacename;
--删除表空间
DROP TABLESPACE SHOP_DEV_DATA
4、查询系统中所有的表空间
SELECT t.TABLESPACE_NAME,t.STATUS FROM DBA_TABLESPACES t
5、查询表空间和数据文件对应关系
SELECT d.TABLESPACE_NAME,d.FILE_NAME FROM DBA_DATA_FILES d
6、查询用户默认的表空间
--查询用户默认的表空间
SELECT u.username,u.default_tablespace FROM DBA_USERS
7、查询表空间中包含哪些表
--查询“SHOP_DEV_DATA”表空间下对应的所有的表
SELECT * FROM USER_TABLES ut
WHERE ut.TABLESPACE_NAME = 'SHOP_DEV_DATA' --名称必须全大写
8、移动表到一个新的表空间
--将newTable移动到users表空间下
ALTER TABLE NEWTABLE MOVE TABLESPACE USERS SELECT * FROM USER_TABLES ut
WHERE ut.TABLESPACE_NAME = 'USERS'
9、修改用户默认表空间
SELECT username,default_tablespace FROM DBA_USERS
--修改shop_user用户默认表空间为users
ALTER USER shop_user DEFAULT TABLESPACE USERS
Oracle基础(三) 表空间的更多相关文章
- Oracle基础 01 表空间 tablespace
--查看表空间 select * from dba_tablespaces; select * from v$tablespace; select * from dba_data_files; --查 ...
- Oracle基础:表空间名称大小写问题
现场环境: 操作系统:windows Oracle版本:10g 今天在通过imp导入数据时,日志提示TS_W5_D表空间不存在.感觉很奇怪,导入用户的表空间是ts_w5_d,并 ...
- oracle基础-创建表空间
一. 创建表空间的完整格式 CREATE [UNDO|TEMPORARY] TABLESPACE tablespace_name DATAFILE 'path/filename' [SIZ ...
- [Oracle]理解undo表空间
一.回退段介绍 在Oracle数据库中,当某个事物对数据进行修改时,Oracle首先将数据的原始值保存到一个回退段中.一个事物只能将它的回退信息保存到一个回退段中,而多个并行事物可以使用同一个回退段. ...
- 删除Oracle用户及表空间
--转载自 https://blog.csdn.net/sunny05296/article/details/81126548--以sysdba用户登录,查找需要删除的用户conn / as sysd ...
- Oracle 删除用户和表空间////Oracle创建删除用户、角色、表空间、导入导出、...命令总结/////Oracle数据库创建表空间及为用户指定表空间
Oracle 使用时间长了, 新增了许多user 和tablespace. 需要清理一下 对于单个user和tablespace 来说, 可以使用如下命令来完成. 步骤一: 删除user drop ...
- 记一次ORACLE的UNDO表空间爆满分析过程
这篇文章是记录一次ORACLE数据库UNDO表空间爆满的分析过程,主要整理.梳理了同事分析的思路.具体过程如下所示: 早上收到一数据库服务器的UNDO表空间的告警邮件,最早一封是7:55发出的(监控作 ...
- Oracle 10g bigfile表空间、smallfile 表空间
smallfile tablespace设置不同大小的db_block_size时数据文件允许的最大大小 db_block_size=2KB,2KB*4M=8192M 8Gdb_block_ ...
- Oracle 10g创建表空间的完整步骤详解
本文我们主要介绍了Oracle 10g创建表空间的完整步骤,包括表空间的创建与删除.为应用创建用户以及权限的授予等操作,希望能够对您有所帮助. AD:WOT2014:用户标签系统与用户数据化运营培训专 ...
- 如何让Oracle释放undo表空间
如何让Oracle释放undo表空间 最佳答案 在日常的数据库维护和数据库编程中经常会遇到犹豫对大数据量做DML操作后是得ORACLE的undo表空间扩展到十几个G或者几十个G 但是这些表空间 ...
随机推荐
- 汕头市队赛 SRM10 T1模拟只会猜题意
模拟只会猜题意 SRM 10 描述 有一本n个单词的词典,求按下列方法能造出的不相同的词汇数目. 1.词典中的单词是一个词. 2.能分为两部分的,其中前一部分是一个词典词或者其非空前缀,后一部分是一 ...
- c#操作SQL的例子
>> 数据表复制 当表目标表存在时: insert into 目的数据库..表 select * from 源数据库..表 当目标表不存在时: select * into 目的数据库..表 ...
- hdu 5146(水题)
Sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Su ...
- PhpStorm 快捷键大全 PhpStorm 常用快捷键和配置+如何关闭快捷键ctrl+alt+方向键旋转屏幕
如果映射的是eclipse的快捷键,又同时安装了英特尔的GPU软件,那么会有这个快捷键冲突 就是快速复制快捷键:ctrl+alt+方向键 会调用英特尔旋转屏幕,禁用掉即可 PhPStorm 是 Je ...
- 最新版 VS2015|Visual Studio Enterprise 2015简体中文版(企业版)
Microsoft Visual Studio(简称VS)是美国微软公司的开发工具包系列产品. Visual Studio 2015 是一个丰富的集成开发环境,可用于创建出色的 Windows.And ...
- RANSAC中迭代次数的计算
假设 $w=\frac{内点个数 }{所有点的个数}$. 则 $p_{0}=w^n$表示采样的$n$个点全为内点的概率(可重复) 则至少有一个为外点的概率$p_{1}=1-p_{0}$ 则重复$K$次 ...
- [jquery] 给动态生成的元素绑定事件 on方法
用底下的方法尝试了好多次都失败 $('.del').on('click',function(){ alert('aa'); })// 失败!! 终于在准备放弃前看到一篇博文说的方法 $(documen ...
- HDU 6336 子矩阵求和
Problem E. Matrix from Arrays Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 ...
- servlet方法
1.每一个Servlet都必须要实现Servlet接口,GenericServlet是个通用的.不特定于任何协议的Servlet,它实现了Servlet接口,而HttpServlet继承于Generi ...
- FZU -2212 Super Mobile Charger(水题)
Problem 2212 Super Mobile Charger Accept: 1033 Submit: 1944Time Limit: 1000 mSec Memory Limit ...