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

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
简介: 【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月前
|
SQL 关系型数据库 MySQL
数据库导入SQL文件:全面解析与操作指南
在数据库管理中,将SQL文件导入数据库是一个常见且重要的操作。无论是迁移数据、恢复备份,还是测试和开发环境搭建,掌握如何正确导入SQL文件都至关重要。本文将详细介绍数据库导入SQL文件的全过程,包括准备工作、操作步骤以及常见问题解决方案,旨在为数据库管理员和开发者提供全面的操作指南。一、准备工作在导
511 0
|
18天前
|
关系型数据库 MySQL 数据库
数据库数据恢复—MYSQL数据库文件损坏的数据恢复案例
mysql数据库文件ibdata1、MYI、MYD损坏。 故障表现:1、数据库无法进行查询等操作;2、使用mysqlcheck和myisamchk无法修复数据库。
|
22天前
|
SQL 关系型数据库 MySQL
MySQL导入.sql文件后数据库乱码问题
本文分析了导入.sql文件后数据库备注出现乱码的原因,包括字符集不匹配、备注内容编码问题及MySQL版本或配置问题,并提供了详细的解决步骤,如检查和统一字符集设置、修改客户端连接方式、检查MySQL配置等,确保导入过程顺利。
|
29天前
|
Oracle 关系型数据库 数据库
Oracle数据恢复—Oracle数据库文件有坏快损坏的数据恢复案例
一台Oracle数据库打开报错,报错信息: “system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。管理员联系我们数据恢复中心寻求帮助,并提供了Oracle_Home目录的所有文件。用户方要求恢复zxfg用户下的数据。 由于数据库没有备份,无法通过备份去恢复数据库。
|
2月前
|
SQL 关系型数据库 MySQL
|
2月前
|
存储 关系型数据库 MySQL
PACS系统 中 dicom 文件在mysql 8.0 数据库中的 存储和读取(pydicom 库使用)
PACS系统 中 dicom 文件在mysql 8.0 数据库中的 存储和读取(pydicom 库使用)
45 2
|
3月前
|
Oracle 关系型数据库 数据库
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
打开oracle数据库报错“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。 数据库没有备份,无法通过备份去恢复数据库。用户方联系北亚企安数据恢复中心并提供Oracle_Home目录中的所有文件,急需恢复zxfg用户下的数据。 出现“system01.dbf需要更多的恢复来保持一致性”这个报错的原因可能是控制文件损坏、数据文件损坏,数据文件与控制文件的SCN不一致等。数据库恢复工程师对数据库文件进一步检测、分析后,发现sysaux01.dbf文件损坏,有坏块。 修复并启动数据库后仍然有许多查询报错,export和data pump工具使用报错。从数据库层面无法修复数据库。
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
|
2月前
|
数据采集 人工智能 自然语言处理
表格增强生成TAG登场:解锁AI自然语言与数据库的完美结合
【10月更文挑战第4天】表格增强生成(TAG)范式解锁了AI自然语言处理与数据库的深度融合,旨在让用户通过自然语言便捷地查询和管理数据。TAG结合了语言模型的强大推理能力和数据库系统的高效计算能力,通过查询合成、执行及答案生成三步完成复杂查询。相较于传统Text2SQL和RAG方法,TAG在准确性上显著提升,但其应用仍面临技术门槛和数据质量等挑战。[论文地址:](https://arxiv.org/pdf/2408.14717)
72 4
|
2月前
|
SQL 存储 关系型数据库
SQL文件导入MySQL数据库的详细指南
数据库中的数据转移是一项常规任务,无论是在数据迁移过程中,还是在数据备份、还原场景中,导入导出SQL文件显得尤为重要。特别是在使用MySQL数据库时,如何将SQL文件导入数据库是一项基本技能。本文将详细介绍如何将SQL文件导入MySQL数据库,并提供一个清晰、完整的步骤指南。这篇文章的内容字数大约在
373 1
|
2月前
|
Java 关系型数据库 数据库连接
SpringBoot项目使用yml文件链接数据库异常
【10月更文挑战第3天】Spring Boot项目中数据库连接问题可能源于配置错误或依赖缺失。YAML配置文件的格式不正确,如缩进错误,会导致解析失败;而数据库驱动不匹配、连接字符串或认证信息错误同样引发连接异常。解决方法包括检查并修正YAML格式,确认配置属性无误,以及添加正确的数据库驱动依赖。利用日志记录和异常信息分析可辅助问题排查。
344 10