介绍
表空间是数据库的逻辑组成部分
从物理上将:数据库数据存放在数据文件中
从逻辑上将:数据库则是存放在表空间中
表空间由一个或是多个数据文件组成
数据库的逻辑结构
介绍:
Oracle中逻辑结构包括表空间、段、区、块
说明:
数据库由表空间构成
而表空间又是由段构成
而段又是由区构成
而区又是由Oracle块构成
这样的一种结果,可以提高数据库的效率
表空间
介绍:
表空间用于从逻辑上组织数据库的数据
数据库逻辑上是由一个或是多个表空间组成的
表空间的作用:
1、控制数据库占用的磁盘空间
2、dba可以将不同数据类型部署到不同的位置。这样有利于提高i/o性能,同时利于备份和恢复等管理操作
oracle创建数据库和用户、表空间
oracle的使用方式和mysql和sql server他们不同,oracle在创建数据库的时候要对应一个用户,数据库和用户一般一一对应,
mysql和sql server 直接通过create databse “数据库名” 就可以直接创建数据库了,而oracle创建一个数据库需要以下三个步骤:
创建两个表空间和对应的数据文件(.DBF),若已存在用户和关联的数据库,则需先删除用户和数据库
创建用户与上面创建的文件形成映射关系
给用户添加权限
一、创建两个表空间和对应的数据文件(monitor.dbf 和monitor_temp.dbf 两个文件) ,若已存在用户和关联的数据库,则需先删除用户和数据库
CREATE TABLESPACE monitor LOGGING DATAFILE 'D:\app\owner\oradata\orcl\monitor.dbf' SIZE 100M AUTOEXTEND ON NEXT 32M MAXSIZE 500M EXTENT MANAGEMENT LOCAL;create temporary tablespace monitor_temp tempfile 'D:\app\owner\oradata\orcl\monitor_temp.dbf'size 100m autoextend on next 32m maxsize 500m extent management local;
tablespace:表空间名
datafile:'数据文件路径'
size:数据文件的大小
maxsize:表数据文件最大大小
uniform size 区的大小;
二、创建用户与上面创建的文件形成映射关系(用户名为monitor,密码为monitor)
CREATE USER monitor IDENTIFIED BY monitor DEFAULT TABLESPACE monitor TEMPORARY TABLESPACE monitor_temp;
三、添加权限
grant connect,resource,dba to monitor;grant create session to monitor;
有时候也会用到删除数据库和删除用户的操作,这里也给出删除的语句
四、删除数据库
DROP TABLESPACE monitor INCLUDING CONTENTS AND DATAFILES;
五、删除用户
drop user monitor cascade;
管理表空间和数据文件简介
建立表空间
建立表空间是使用create tablespace命令完成的,要注意时,一般情况下,建立表空间是特权用户或是dba来执行的,
如果用其它用户来创建表空间,则用户必须要具有create tablespace的系统权限
建立数据表空间
在建立数据库后,为便于管理表,最好建立自己的表空间
create tablespace tangtao001 datafile 'd:\t001.dbf' size 20m uniform size 128k;
使用数据表空间
向新建的表空间添加表:
create table myDept(deptno number(4),dname varchar2(15),loc varchar2(13)) tablespace tangtao001;
说明:执行完上述命令后,会建立名称为tangtao001 的表空间,并为该表空间建立名称为t001.dbf的数据文件,区的大小为128k
1、显示表空间信息
a) 查询数据字典视图dba_tablespaces。显示表空间信息
select tablespace_name from dba_tablespaces;
2、显示表空间所包含的数据文件
a) 查询数据字典视图dba_data_files,可以显示表空间所包含的数据文件
select file_name,bytes from dba_data_files where tablespace_name='表空间名';
改变表空间的状态
当建立表空间时,表空间处于联机的(online)状态,此时该表空间是可以访问的,并且该表空间是可以读写的,即可以查询该表空间的数据,而且还可以在表空间执行各种语句。
但.........