回顾数据库的三级模式,为什么比直接存文件表格好?

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 【6月更文挑战第10天】本文介绍数据库用于解决Excel等文件系统存在的数据冗余、不一致和访问困难等问题。DBMS中的关系有一对一、一对多、多对一和多对多四种类型。键有候选键、超级键、主键、备用键和外键等类型,功能依赖分为平凡和非平凡两种。

1 简介

为什么会有数据库存在? 直接使用excel这样的文件有哪些问题?

mandala曼德罗符号.png

在关系型数据库中通过DBMS实现了数据的有效管理,包括外模式(用户视图)、概念模式(整体逻辑结构)和内模式(物理存储)。数据模型包含实体、属性和关系,如强实体、弱实体、键属性等。

它们能解决传统文件系统的问题:

数据冗余:相同的数据可以存储在多个地方。

    数据不一致:如果同一数据的多个副本在每个副本中具有不同的内容。
    例如,学生的电话号码在学术和帐户文件中是不同的。

数据访问:在文件系统中,访问数据也很困难且不安全。无法同时访问数据。
无备份和恢复:文件系统中没有可能导致数据丢失的备份和恢复。

而使用关系型数据库可很好地解决这些问题。

2 DBMS关系模式

如何查看和修改你的数据库关系模式?

  • 查看

         select @@session .sql_mode;
    
  • 修改:

          set @@session.sql_mode='xx_mode'
          set session sql_mode='xx_mode'
    
  • 配置修改(永久生效):

          打开 vi /etc/my.cnf
          [mysqld]
          sql-mode = "xx_mode"
    

3 具体含义

三级模式 外模式,概念模式,内模式

1、外模式

对应数据库的升级、外模式包括(子模式 用户模式) 用来描述用户看到或者使用那部分的数据的逻辑结构,用户根据外模式用户数据操作语句或者程序去操作数据库中的数据,外模式的主要特点用来描述组成用户视图各个记录的组成、相互联系、数据的完整性和安全性、数据项的特征等。

2、概念模式

对应数据库的概念模式,概念模式(概念、逻辑模式)用以描述整个数据库中的逻辑结构、用来描叙现实生活中的实体,以及它们之间的关系、从而定义记录数据项的完整性约束条件以及记录之间的联系是数据项的框架 概念模式是数据库中全体数据的逻辑结构和特征的描叙是所有用户数据的公共数据视图。

3、内模式

内模式对应物理级数据库,内模式是所有模式中的最低层的表示,不同于物理层,假设外存是一个无限性的地址空间,内模式是存储记录的类型,存储域以及表示以及存储记录的物理顺序,指示元索引,和存储路径的等数据的存储组织从而形成一个完整的系统

4 数据模型属性和关系

  • 实体:

实体是真实世界的对象,使用矩形框表示。

  • 强实体:
    强实体集有一个主键,可以使用该主键识别该集的所有元组

  • 弱实体:

当实体没有足够的属性来形成主键时。弱实体与另一个强实体集相关联,也称为标识实体。弱实体的存在取决于其识别实体的存在。弱实体使用双线或粗线矩形表示。

  • 属性:

属性是真实世界对象的属性或特征。它使用椭圆表示。

  • 键属性:

唯一确定每个实体的属性称为键属性。它由带有底线的椭圆表示。

  • 复合属性:

由许多其他属性组成的属性。 例如,地址是由州、区、市、街道等其他属性组成的属性。它使用由许多其他椭圆组成的椭圆表示。

  • 多值属性:

可以具有多个值的属性,例如手机号码。它使用双线椭圆表示。

  • 派生属性:

可以从其他属性派生的属性。 例如,年龄是一个属性,可以从另一个属性“出生数据”派生。它使用虚线椭圆表示。

  • 关系:

关系是两个或多个实体之间的关联。实体相互连接或相关,这种关系使用菱形表示。

5 DBMS数据表之间关系

DBMS 关系可以定义为实体集的实体参与关系集的次数。

假设两个实体集 A 和 B 之间存在二元关系 R。关系必须具有以下映射基数之一:

一对一:

当 A 的一个实体最多与 B 的一个实体相关时,反之亦然。

一对多:

当 A 的一个实体与 B 的一个或多个实体相关时,而 B 最多与 A 中的一个实体相关联。

多对一:

当 B 的一个实体与 A 的一个或多个实体相关时,而 A 与 B 中的最多一个实体相关联。

多对多:

A 的任意数量的实体与 B 的任意数量的实体相关,反之亦然。
ER 图中最常见的问题是给定 ER 图中所需的最小表数。

如果关系是一对多或多对一,则可以组合两个或多个关系表。

如果关系为多对多,则不能合并两个表。

如果关系是一对一的,并且有一个实体完全参与,则该实体可以与关系表组合。

如果两个实体都完全参与,则可以通过组合一个表和关系的两个实体来获得一个表。

注意:这是一般性意见。特殊情况需要处理。如果关系的属性无法移动到任何实体端,我们可能需要一个额外的表。

6 数据表中各种键

键:关系中有各种类型的键,它们是:

候选键:可以唯一确定元组的最小属性集。关系可以有多个候选键,其适当的子集不能唯一地确定元组,也不能为 NULL。

超级键:可以唯一确定元组的属性集。候选键始终是超级键,反之亦然。

主键和备用键:在各种候选键中,一个键作为主键,其他键是备用键。

外键:外键是表中的一组属性,用于引用同一表或另一个表的主键或备用键。

功能依赖关系:它是指定一组属性之间的关联/关系的约束。

在函数依赖关系中,一个集合可以准确地确定另一个集合的值。

7 小结

功能依赖关系进一步分为两种类型:

功能依赖:
在函数依赖中,如果B是A的子集,那么这种依赖被称为平凡功能依赖。

非平凡功能依赖:
在功能依赖中,如果 B 不是 A 的子集,则这种依赖称为非平凡功能依赖。

具体可查看之前的文章。

目录
相关文章
|
2月前
|
存储 NoSQL 数据库
Redis 逻辑数据库与集群模式详解
Redis 是高性能内存键值数据库,广泛用于缓存与实时数据处理。本文深入解析 Redis 逻辑数据库与集群模式:逻辑数据库提供16个独立存储空间,适合小规模隔离;集群模式通过分布式架构支持高并发和大数据量,但仅支持 database 0。文章对比两者特性,讲解配置与实践注意事项,并探讨持久化及性能优化策略,助你根据需求选择最佳方案。
111 5
|
18天前
|
存储 SQL Java
数据存储使用文件还是数据库,哪个更合适?
数据库和文件系统各有优劣:数据库读写性能较低、结构 rigid,但具备计算能力和数据一致性保障;文件系统灵活易管理、读写高效,但缺乏计算能力且无法保证一致性。针对仅需高效存储与灵活管理的场景,文件系统更优,但其计算短板可通过开源工具 SPL(Structured Process Language)弥补。SPL 提供独立计算语法及高性能文件格式(如集文件、组表),支持复杂计算与多源混合查询,甚至可替代数据仓库。此外,SPL 易集成、支持热切换,大幅提升开发运维效率,是后数据库时代文件存储的理想补充方案。
|
30天前
|
存储 关系型数据库 MySQL
【赵渝强老师】OceanBase数据库从零开始:MySQL模式
《OceanBase数据库从零开始:MySQL模式》是一门包含11章的课程,涵盖OceanBase分布式数据库的核心内容。从体系架构、安装部署到租户管理、用户安全,再到数据库对象操作、事务与锁机制,以及应用程序开发、备份恢复、数据迁移等方面进行详细讲解。此外,还涉及连接路由管理和监控诊断等高级主题,帮助学员全面掌握OceanBase数据库的使用与管理。
123 5
|
4月前
|
SQL 数据建模 BI
【YashanDB 知识库】用 yasldr 配置 Bulkload 模式作单线程迁移 300G 的业务数据到分布式数据库,迁移任务频繁出错
问题描述 详细版本:YashanDB Server Enterprise Edition Release 23.2.4.100 x86_64 6db1237 影响范围: 离线数据迁移场景,影响业务数据入库。 外场将部分 NewCIS 的报表业务放到分布式数据库,验证 SQL 性能水平。 操作系统环境配置: 125G 内存 32C CPU 2T 的 HDD 磁盘 问题出现的步骤/操作: 1、部署崖山分布式数据库 1mm 1cn 3dn 单线启动 yasldr 数据迁移任务,设置 32 线程的 bulk load 模式 2、观察 yasldr.log 是否出现如下错
|
8月前
|
SQL 关系型数据库 MySQL
数据库导入SQL文件:全面解析与操作指南
在数据库管理中,将SQL文件导入数据库是一个常见且重要的操作。无论是迁移数据、恢复备份,还是测试和开发环境搭建,掌握如何正确导入SQL文件都至关重要。本文将详细介绍数据库导入SQL文件的全过程,包括准备工作、操作步骤以及常见问题解决方案,旨在为数据库管理员和开发者提供全面的操作指南。一、准备工作在导
1202 0
|
4月前
|
存储 NoSQL MongoDB
数据库数据恢复—MongoDB数据库迁移过程中丢失文件的数据恢复案例
某单位一台MongoDB数据库由于业务需求进行了数据迁移,数据库迁移后提示:“Windows无法启动MongoDB服务(位于 本地计算机 上)错误1067:进程意外终止。”
|
6月前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
6月前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
7月前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。