Oracle数据库的体系结构包括四个方面:数据库的物理结构、逻辑结构、内存结构及进程。
1 物理结构
物理数据库结构是由构成数据库的 *** 作系统文件所决定,Oracle数据库文件包括:
数据文件(Data File)
数据文件用来存储数据库中的全部数据,例如数据库表中的数据和索引数据通常以为dbf格式,例如:userCIMSdbf 。
日志文件(Redo Log File)
日志文件用于记录数据库所做的全部变更(如增加、删除、修改)、以便在系统发生故障时,用它对数据库进行恢复。名字通常为Logdbf格式,如:Log1CIMSdbf,Log2CIMSdbf 。
控制文件(Control File)
每个Oracle数据库都有相应的控制文件,它们是较小的二进制文件,用于记录数据库的物理结构,如:数据库名、数据库的数据文件和日志文件的名字和位置等信息。用于打开、存取数据库。名字通常为Ctrlctl 格式,如Ctrl1CIMSctl。
配置文件
配置文件记录Oracle数据库运行时的一些重要参数,如:数据块的大小,内存结构的配置等。名字通常为initora 格式,如:initCIMSora 。
2 逻辑结构
Oracle数据库的逻辑结构描述了数据库从逻辑上如何来存储数据库中的数据。逻辑结构包括表空间、段、区、数据块和模式对象。数据库的逻辑结构将支配一个数据库如何使用系统的物理空间模式对象及其之间的联系则描述了关系数据库之间的设计
一个数据库从逻辑上说是由一个或多个表空间所组成,表空间是数据库中物理编组的数据仓库,每一个表空间是由段(segment)组成,一个段是由一组区(extent)所组成,一个区是由一组连续的数据库块(database block)组成,而一个数据库块对应硬盘上的一个或多个物理块。一个表空间存放一个或多个数据库的物理文件(即数据文件)一个数据库中的数据被逻辑地存储在表空间上。
表空间(tablespace)
Oracle数据库被划分为一个或多个称为表空间的逻辑结构,它包括两类表空间,System表空间和非System表空间,其中,System表空间是安装数据库时自动建立的,它包含数据库的全部数据字典,存储过程、包、函数和触发器的定义以及系统回滚段。除此之外,还能包含用户数据。。
一个表空间包含许多段,每个段有一些可以不连续的区组成,每个区由一组连续的数据块组成,数据块是数据库进行 *** 作的最小单位。
每个表空间对应一个或多个数据文件,每个数据文件只能属于一个表空间。
数据库块(database block)
数据库块也称逻辑块或ORACLE块,它对应磁盘上一个或多个物理块,它的大小由初始化参数db-block-size(在文件initora中)决定,典型的大小是2k。Pckfree 和pctused 两个参数用来优化数据块空间的使用。
区(extent)
区是由一组连续的数据块所组成的数据库存储空间分配的逻辑单位。
段(segment)
段是一个或多个不连续的区的集合,它包括一个表空间内特定逻辑结构的所有数据,段不能跨表空间存放。Oracle数据库包括数据段、索引段、临时段、回滚段等。
模式对象(schema object)
Oracle数据库的模式对象包括表、视图、序列、同意词、索引、触发器、存储过程等,关于它们将重点在后面章节介绍。
3.Oracle Server系统进程与内存结构
当在计算机服务器上启动Oracle数据库后,称服务器上启动了一个Oracle实例(Instance)。ORACLE 实例(Instance)是存取和控制数据库的软件机制,它包含系统全局区(SGA)和ORACLE进程两部分。SGA是系统为实例分配的一组共享内存缓冲区,用于存放数据库实例和控制信息,以实现对数据库中数据的治理和 *** 作。
进程是 *** 作系统中一个极为重要的概念。一个进程执行一组 *** 作,完成一个特定的任务对ORACLE数据库治理系统来说,进程由用户进程、服务器进程和后台进程所组成。
当用户运行一个应用程序时,系统就为它建立一个用户进程。服务器进程处理与之相连的用户进程的请求,它与用户进程相通讯,为相连的用户进程的ORACLE请求服务。
为了提高系统性能,更好地实现多用户功能,ORACLE还在系统后台启动一些后台进程,用于数据库数据 *** 作。
系统进程的后台进程主要包括:
SMON 系统监控进程:(system monitor)负责完成自动实例恢复和回收分类(sort)表空间。
PMON 进程监控进程:(PRocess monitor)实现用户进程故障恢复、清理内存区和释放该进程所需资源等。
DBWR 数据库写进程:数据库缓冲区的治理进程。
在它的治理下,数据库缓冲区中总保持有一定数量的自由缓冲块,以确保用户进程总能找到供其使用的自由缓冲块。
LGWR 日志文件写进程:是日志缓冲区的治理进程,负责把日志缓冲区中的日志项写入磁盘中的日志文件上。每个实例只有一个LGWR进程。
ARCH 归档进程:(archiver process)把已经填满的在线日志文件拷贝到一个指定的存储设备上。仅当日志文件组开关(switch)出现时,才进行ARCH *** 作。ARCH不是必须的,而只有当自动归档可使用或者当手工归档请求时才发出。
RECO 恢复进程:是在具有分布式选项时使用的一个进程,主要用于解决引用分布式事务时所出现的故障。它只能在答应分布式事务的系统中出现。
LCKn 封锁进程:用于并行服务器系统,主要完成实例之间的封锁。
内存结构(SGA)
SGA是Oracle为一个实例分配的一组共享内存缓冲区,它包含该实例的数据和控制信息。SGA在实例启动时被自动分配,当实例关闭时被收回。数据库的所有数据 *** 作都要通过SGA来进行。
SGA中内存根据存放信息的不同,可以分为如下几个区域:Buffer Cache:存放数据库中数据库块的拷贝。它是由一组缓冲块所组成,这些缓冲块为所有与该实例相链接的用户进程所共享。缓冲块的数目由初始化参数DB_BLOCK_BUFFERS确定,缓冲块的大小由初始化参数DB_BLOCK_SIZE确定。大的数据块可提高查询速度。它由DBWR *** 作。
b 日志缓冲区Redo Log Buffer:存放数据 *** 作的更改信息。它们以日志项(redo entry)的形式存放在日志缓冲区中。当需要进行数据库恢复时,日志项用于重构或回滚对数据库所做的变更。日志缓冲区的大小由初始化参数LOG_BUFFER确定。大的日志缓冲区可减少日志文件I/O的次数。后台进程LGWR将日志缓冲区中的信息写入磁盘的日志文件中,可启动ARCH后台进程进行日志信息归档。
c 共享池Shared Pool:包含用来处理的SQL语句信息。它包含共享SQL区和数据字典存储区。共享SQL区包含执行特定的SQL语句所用的信息。数据字典区用于存放数据字典,它为所有用户进程所共享。
Cursors:一些内存指针,执行待处理的SQL语句
其他信息区:除了上述几个信息区外,还包括一些进程之间的通讯信息(如封锁信息);在多线索服务器配置下,还有一些程序全局区的信息,请求队列和响应队列等。 本文来自: >
1、查看所有表空间及表空间大小:
select tablespace_name ,sum(bytes) / 1024 / 1024 as MB from dba_data_files group by tablespace_name;
2、查看所有表空间对应的数据文件:
select tablespace_name,file_name from dba_data_files;
3、修改数据文件大小:
alter database datafile 'H:\ORACLE\PRODUCT\1010\ORADATA\ORACLE\USERS01DBF' RESIZE 10240M;
扩展资料
每张表都是作为“段”来存储的,可以通过user_segments视图查看其相应信息。
段(segments)的定义:如果创建一个堆组织表,则该表就是一个段。
sql:SELECT segment_name AS TABLENAME,BYTES FROM user_segments WHERE segment_name='表名'。
解释:
segment_name 就是要查询的表名(大写),BYTES 为表存储所占用的字节数。本sql的意思就是查询出表名和表所占的存储空间大小。
参考资料
csdn:怎么查看oracle数据库大小
顾名思义就是存储数据的
不是所有的软件都需要装数据库,
数据库大都装在服务器上,比如你访问的网页,数据就是存在互联网服务器上,所以一般的个人电脑都没有安装数据库软件,只有访问的组件,
还有就是有一些单机数据库,你的软件安装的时候就已经安装好了,只是,没有通知你,比如ACCESS,SYBASE
ASA,他们有的只需要简单的配置注册表,和一些驱动就可以运行了
ORACLE由两部分:实例和数据库\x0d\实例由以下组成: SGA,Shared pool,Database buffer cache,Redo log buffer cache\x0d\数据库由物理文件组成,其中必须有的文件是:数据文件,控制文件,重做日志\x0d\另外还有:参数文件,口令文件,归档日志文件(这三个不是必须的)\x0d\ORACLE SERVER 由两个部分组成,\x0d\1INSTANCE:又由内存结构和后台进程组成\x0d\2DATABASE:又由数据文件,日志文件和控制文件组成\x0d\CONTROL FILE是用来连接实例和DATABASE的\x0d\SQL>SHUTDOWN IMMEDIATE\x0d\SQL>STARTUP NOMOUNT\x0d\SQL>ALTER DATABASE MOUNT\x0d\以上三个过程就是通过CONTROL FILE来连接实例和数据库\x0d\SQL>ALTER DATABASE OPEN\x0d\在OPEN的过程对DATABASE的数据文件和重做日志文件进行一次性的验证,验证它们的状态\x0d\ORACLE INSTANCE:存取数据库的一个手段\x0d\ 一个DATABASE与INSTANCE之间是1:N的关系,一个INSTANCE只能 *** 作一个DATABASE,由内存结构(共享池,\x0d\ BUFFER CACHE,REDO LOG BUFFER CACHE)及相应的进程结构组成(PMON,SMON,CKPT)\x0d\SQL>SHOW SGA ---显示DATABASE内存结构信息\x0d\SQL>SET WRAP OFF\x0d\SQL>SET LINESIZE 200\x0d\以上这两个是设置行宽\x0d\SQL>SELECT FROM V$BGPROCESS;\x0d\将看到在这个系统中所有可能使用到的进程,其中PADDR并不每个进程都分配到有效的地址,即并不是每个进程都是必须的\x0d\SQL>SELECT FROM V$BGPROCESS WHERE PADDR\'00\'\x0d\将显示所有必需的进程\x0d\ESTABLISHING A CONNECTION AND CREATING A SESSION\x0d\连接到ORACLE实例包括建立一个用户连接及创建会话\x0d\\x0d\ORACLE MEMORY STRUCTURE (内存结构)\x0d\由两部分组成:\x0d\ 1SGA\x0d\ SGA是动态的,其最大值由SGA_MAX_SIZE指定,SGA的内存由SGA COMPONENTS来动态调整\x0d\ 2PGA 是不共享的,即其包含的信息是不一样的,有两个可享的内存可以由SGA配置\x0d\ LARGE POOL\x0d\ JAVA POOL\x0d\SQL>SHOW PARAMETER SHARED\x0d\SQL>SHOW PARAMETER DB_CACHE\x0d\SQL>SHOW PARAMETER LOG\x0d\以上三个命令是用于查看相关内存信息\x0d\SQL>ALTER SYSTEM SET DB_CACHE_SIZE=20M;\x0d\所有内存大小总和不能大于SGA_MAX_SIZE的值,当提示信息出现号或乱码时,是由于系统的语言问题\x0d\可以通过ALTER SESSION SET NLS_LANGUAGE=\'AMERICAN\'或ALTER SESSION SET NLS_LANGUAGE=\"SIMPLE\x0d\[Page]\x0d\CHINESE\"\x0d\SHARED POOL (共享池)\x0d\含:LIBRARY CACHE 库缓存\x0d\ DATA DICTIONARY CACHE 数据字典缓存,有的地方又称行CACHE,由SHARED_POOL_SIZE指定大小\x0d\SQL>ALTER SYSTEM SET SHARED_POOL_SIZE=64M;\x0d\LIBRARY CACHE 主要为提高代码的共享,存储的是最近使用的SQL和PL/SQL代码\x0d\用最近最少使用(LRU)算法\x0d\包括两个结构 1:共享SQL代码 2:共享PL/SQL代码\x0d\不可直接定义,而由SHARED POOL SIZE决定\x0d\DATA DICTONARY CACHE\x0d\执行此命令的过程是:首先确认是否存在AUTHORS,,然后确认字段存不存在,再检查语法,最后验证权限,而\x0d\这些信息就属于DATA DICTIONARY CACHE的内容其包含的信息有:DATABASE FILES,表,索引,字段,用户,\x0d\权限和其他数据库对象
顾名思义就是存储数据的\x0d\不是所有的软件都需要装数据库,\x0d\数据库大都装在服务器上,比如你访问的网页,数据就是存在互联网服务器上,所以一般的个人电脑都没有安装数据库软件,只有访问的组件,\x0d\还有就是有一些单机数据库,你的软件安装的时候就已经安装好了,只是,没有通知你,比如ACCESS,SYBASE ASA,他们有的只需要简单的配置注册表,和一些驱动就可以运行了
以上就是关于oracle 数据库 是什么结构全部的内容,包括:oracle 数据库 是什么结构、怎么查看oracle数据库数据量大小、Oracle数据库主要是干什么的等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)