在oRacLe数据库中,
模式对应整个数据库中的表、索引、序列;
外模式对应某个用户的表、索引、序列、视图、同义词,也称为“方案对象”;
内模式对应存储结构,比如逻辑存储结构(表空间、区、段、块等)、物理存储结构(数据文件、控制文件、重做日志文件、初始化参数文件、配置文件等)。
其他数据库类似。
我用了db2,其中就有模式schmea关键词,但这个概念比较虚,更多人愿意使用owneR这个关键词。
最大的问题在于电脑不是中国人发明的,数据库概念也不是,模式的词汇是硬翻译过来的。
个人认为模式,就是架构层次的意思,
模式:总体架构及设计方式
外模式:用户层,所有与使用者程序或用户打交道的一系列概念
内模式:存储层,所有与数据存储方式打交道的一系列概念
如果要以视图访问来看,就更典型:
seLect * FRom 数据库.a视图
a视图纯粹用于用户层
而视图->表->表空间的整体架构就是数据库模式
a视图基于 b,c,d表
b,c,d表又位于b,c,d表空间
那么 a->b,c,d就是外模式到模式的对应, b,c,d=>到b,c,d就是模式到内模式的对应
内模式不仅包含表如何存放到表空间,表空间如何在文件上存储,还要关心表空间如何分页、分段、分区等。
原文地址:https://www.weidianyuedu.com/content/2520663686226.html