数据库系统的三级模式与两层映像:一个汉堡店的类比
创作时间:
作者:
@小白创作中心
数据库系统的三级模式与两层映像:一个汉堡店的类比
引用
CSDN
1.
https://blog.csdn.net/2302_76739243/article/details/142342567
数据库系统的三级模式结构是理解数据库逻辑与物理存储关系的基础。本文将通过一个汉堡店的例子,帮助读者更好地理解这一概念。
数据库系统的三级模式结构
模式(逻辑模式)
- 定义:数据库全体数据的逻辑结构和特征的描述
- 特点:所有用户的公共数据视图,位于中间层逻辑级
外模式(子模式/用户模式)
- 定义:数据库用户能够看见和使用的局部数据的逻辑结构和特征的描述
- 特点:数据库用户的数据视图,与某一应用有关的数据的逻辑表示,是模式的子集
内模式(存储模式)
- 定义:数据物理结构和存储方式的描述
- 特点:一个数据库只有一个内模式,描述数据在数据库内部的组织方式
数据库的二级映像
外模式/模式映像
- 定义:定义外模式与模式之间的对应关系
- 作用:当模式改变时,由数据库管理员对各个外模式/模式的映像作相应改变,可以使外模式保持不变。应用程序仅依据外模式编写,保证数据的逻辑独立性
模式/内模式
- 定义:定义数据全局逻辑结构与存储结构之间的对应关系
- 作用:当存储结构改变时,由数据库管理员对各个模式/内模式的映像作相应改变,可以使模式保持不变,从而应用程序也不必改变,保证物理独立性
生活化类比:汉堡店的例子
假设你想吃汉堡,要那种:两片烤的香喷喷的面包皮,中间夹着令人疯狂分泌唾液的肉和菜,简直就是人间仙品,但具体口味你还没想好。于是你来到一家汉堡店,看着菜单栏上的各种口味的汉堡:
汉堡的概念与数据库模式的对应
- 汉堡的概念:所有人都知道它大致的样子,就像上面描述的一样(两块面包皮夹着肉和菜)。这可以看做数据库的逻辑模式即模式,也就是三层模式结构的中间层。
- 菜单上的各种口味的汉堡:可以视为外模式(用户模式)。鸡肉,牛肉还是素食,全都由用户直接接触和选择。你可以看到,且只能看到你选择的这款汉堡,在两片面包皮里加了什么,以及它的价格等。但你不可能知道它的制作方法,面包皮里有多少面粉,调味酱里到底加了什么。
- 内模式:可以是汉堡的制作和存储秘方,像美味蟹黄堡秘方一样,只有特定的人知道。但蟹黄堡秘方决定了蟹黄堡的制作流程,配料,比例等等,就像数据需要规定排序方式,存储记录结构等等。
映像关系的类比
- 外模式/模式映像:就像是餐厅的菜单与顾客点的汉堡之间的关系。餐厅的菜单(模式)提供了所有可供选择的汉堡种类(外模式),顾客根据自己的喜好(用户视图)选择特定的汉堡。即使餐厅内部改变了某些汉堡的配方(模式的变更),只要这些变更不影响顾客点的汉堡(外模式),顾客就不需要知道这些变化。
- 模式与内模式之间的映像:就像是餐厅的后厨与菜单之间的关系。餐厅的菜单(模式)定义了汉堡的组成,而后厨(内模式)负责具体的制作和存储。如果后厨改变了烹饪方法(内模式的变更),比如今天的鸡排少炸了10秒,只要这些变更不影响菜单上汉堡的描述(概念模式),顾客也不需要知道这些变化。
通过这个生活化的例子,我们可以更直观地理解数据库系统的三级模式和两级映像的概念。希望这个类比能帮助你更好地掌握这一知识点。
热门推荐
探秘:房车露营车改装重型滑轨的黑科技
冬季饮食如何拯救你的坏心情?
燕麦早餐,结肠炎患者的新宠?
广东省中医院专家:情绪管理是治疗结肠炎的关键环节
抽油烟机选购指南:三种类型对比与选购要点
选购油烟机指南:从吸力到设计,全方位解析关键要素
如何判断油烟机的吸力大小(了解吸力大小的关键指标及选择油烟机的技巧)
国机汽车财报揭秘:营收下降为何净利润大增?
钳鱼养殖技术与经济价值分析
爬泰山何必只走红门?还有最浪漫与最省力的登山路,攻略
存款利率高达4.05%,竟有这种好事?黄牛称“银行有新户福利”,律师:谨防诈骗!
公司破产后,员工工资的优先受偿权是什么?
颌下腺结石自行排出方法有哪些
探访白娘子传说地:镇江金山寺
镇江西津渡:千年古渡的文化传承与现代新生
西津渡:镇江千年的历史见证
知识分享|超纤皮革 环保性能评估指南
土茯苓的功效与使用指南
妙佑医疗专家推荐:腹泻呕吐的家庭护理指南
广东省人民医院专家详解:泼尼松治疗结肠炎的正确使用方法
溃疡性结肠炎患者饮食指南:从禁忌到推荐,全面实用的饮食管理方案
中国企业出海法规合规和风险防范
中企出海现状、特点与风险防范
中国企业出海策略:多元化路径与本土化运营
情人节必看!十二星座专属约会指南
十二星座友情维护大揭秘!
十二星座恋爱观大揭秘:谁是最容易被误解的“恋爱脑”?
左锁骨下方隐隐疼痛怎么办?可能病因及处理建议
春节零食选购指南:营养师推荐这两类“健康款”
大山里的天籁之音:凉山妞妞合唱团的春晚圆梦之旅