当前位置: 首页 > news >正文

基于 ‌MySQL 数据库‌对三级视图(用户视图、DBA视图、内部视图)的详细解释

基于 ‌MySQL 数据库‌对三级视图(用户视图、DBA视图、内部视图)的详细解释,结合理论与实际操作说明:

一、三级视图核心概念

数据库的三级视图是 ANSI/SPARC 体系结构的核心思想,MySQL 的实现逻辑如下:

层级别称核心内容MySQL 中的体现
用户视图外模式/子模式用户看到的数据逻辑结构用户权限内的表、视图、可操作字段
DBA视图概念模式/逻辑模式全局逻辑结构、表关系、约束information_schemamysql 系统库元数据
内部视图内模式/存储模式物理存储结构、索引、文件组织方式InnoDB/MyISAM 存储引擎的物理文件、缓存机制


二、用户视图(外模式)

1. 定义

用户视角下可见的数据集合,‌权限隔离‌是核心特性。

2. MySQL 实现
‌权限控制‌:通过 GRANT/REVOKE 限制用户对表、字段的访问。
‌操作示例‌:

-- 创建用户并限制访问权限
CREATE USER 'user1'@'%' IDENTIFIED BY 'password';
GRANT SELECT ON db1.employee TO 'user1'@'%';  -- 仅允许查询 employee 表-- 用户登录后只能看到授权对象
SHOW DATABASES;       -- 仅显示有权限的数据库
SELECT * FROM salary; -- 无权访问时报错:ERROR 1142 (42000)

三、DBA视图(概念模式)

1. 定义

DBA 或开发者看到的‌全局逻辑结构‌,包括所有表、字段、约束、用户权限等。

2. MySQL 实现
‌系统库 information_schema‌:存储元数据(表、列、索引等)。
‌操作示例‌:

-- 查看所有数据库中的表
SELECT table_name, table_type 
FROM information_schema.tables 
WHERE table_schema = 'db1';-- 查看用户权限
SELECT * FROM mysql.user WHERE user = 'user1';  -- 用户密码、权限字段

四、内部视图(内模式)

1. 定义

数据在磁盘的‌物理存储形式‌,由存储引擎(如 InnoDB)实现。

2. MySQL 实现
‌物理文件结构‌:
.frm:表结构定义文件(MySQL 8.0 后移除,元数据存于系统表)
.ibd:InnoDB 表的数据和索引文件(独立表空间模式)
‌操作示例‌:

-- 查看数据存储路径
SHOW VARIABLES LIKE 'datadir';  -- 输出如 /var/lib/mysql/-- 查看 InnoDB 存储细节
SHOW ENGINE INNODB STATUS;      -- 事务、锁、缓冲池状态

五、三级视图关系总结

graph TBA[用户视图] -->|通过外模式-模式映射| B[DBA视图]B -->|通过模式-内模式映射| C[内部视图]C -->|存储引擎解析| D[物理文件]


‌关键点‌:

‌用户无需关心物理存储‌,只需通过 SQL 操作逻辑表。
‌DBA 维护映射规则‌,如通过 ALTER TABLE 修改存储引擎而不影响用户视图。
‌存储引擎透明性‌:InnoDB 的 B+树索引、MyISAM 的堆表结构对用户不可见。

http://www.lryc.cn/news/544007.html

相关文章:

  • [Web 信息收集] Web 信息收集 — 手动收集 IP 信息
  • 跨AWS账户共享SQS队列以实现消息传递
  • DeepSeek 202502 开源周合集
  • springai系列(二)从0开始搭建和接入azure-openai实现智能问答
  • Apache部署Vue操作手册(SSL部分)
  • 人类驾驶的人脑两种判断模式(反射和预判)-->自动驾驶两种AI模式
  • Docker和K8S中pod、services、container的介绍和关系
  • 【uniapp】在UniApp中实现持久化存储:安卓--生成写入数据为jsontxt
  • DeepSeek-R1本地部署保姆级教程
  • Python常见面试题的详解25
  • DeepSeek赋能大模型内容安全,网易易盾AIGC内容风控解决方案三大升级
  • 阿里开源正式开园文生视频、图生视频模型-通义万相 WanX2.1
  • 【Python爬虫(73)】用Python爬虫开启交通数据宝藏,畅行出行未来
  • 和鲸科技携手四川气象,以 AI 的力量赋能四川气象一体化平台建设
  • spring boot 2.7 + seata +微服务 降级失败问题修复
  • python-leetcode-最长公共子序列
  • centos 7 停更后如何升级kernel版本 —— 筑梦
  • WPF-3天快速WPF入门并达到企业级水准
  • 爬虫反爬:CSS位置偏移反爬案例分析与实战案例
  • Ubuntu20.04安装Redis
  • Ubuntu 22.04 安装Nvidia驱动加速deepseek
  • OkHttp、Retrofit、RxJava:一文讲清楚
  • 星环科技推出DeepSeek全场景解决方案:即开即用、企业级部署、端侧智能三位一体
  • Redis缓存一致性难题:如何让数据库和缓存不“打架”?
  • 动态部署Web应用程序与web.xml配置详解
  • 2025年软考报名费用是多少?全国费用汇总!
  • DeepSeek 15天指导手册——从入门到精通 PDF(附下载)
  • 【Javascript】js精度丢失
  • 让Word插上AI的翅膀:如何把DeepSeek装进Word
  • 秒杀系统的常用架构是什么?怎么设计?