数据库系统概念(第二周 第一堂)

前言

本文的所有知识点、图片均来自《数据库系统概念》(黑宝书)、山东大学李晖老师PPT。不可用于商业用途转发。

回顾

        上周最后一个知识点说到数据库三级模式结构,在这个结构里面我们设立了模式/内模式映像内模式/外模式映像,主要为了解决数据独立性的问题。数据独立性又分为物理数据独立性逻辑数据独立性

数据模型

定义

数据模型是一个描述数据、数据联系、数据语义以及一致性约束的概念工具的集合

数据模型的选择本质上就是选择一个存放数据的方式,这个存放数据包括数据的物理存放、逻辑关系以及语义联系等

由定义可知,数据库的设计最核心的部分就是物理存放设计(数据底层存储方式),逻辑存放设计(设计数据在业务层面的逻辑关系)

分类

关系模型:用表的集合表示数据和数据之间的关系

实体-联系模型:现实世界是由实体和实体之间的联系构成的,用于数据库设计

基于对象数据模型:实体-联系模型增加了封装、方法和对象标识等拓展

组成要素

一、数据结构:数据库中对象类型的集合(与数据内容、类型有关的对象,与数据之间联系有关的对象),是对系统静态特性的描述。

数据结构课程中的数据结构是指数据的类型以及组织方式(数组/动静态数组、链表/单双链表等等),数据库中的数据结构是指数据库中数据的结构即数据的类型

二、数据操作:包括检索、更新两个方面,是对系统动态特性的描述。

数据操作在数据结构课程中对应的就是数据的组织方式和数据类型,或者说数据的组织方式和数据类型两者共同决定数据操作

三、数据约束条件:一组完整性规则的集合

关系模型

关系模型在现代已经全面取代了其他两类模型,故数据库中讨论的只有关系模型。

初识

优点 

一、简单。只有关系一种数据结构,同时逻辑上的数据结构也只有表这一种形式。

二、非过程化数据请求,数据请求可以不指明路径。(非过程化数据请求,说明关系数据库的数据获取更多是一种静态批量的数据获取)

三、数据独立性。用户只需提出做什么,不用考虑怎么做

四、坚实的理论基础

数据库语言

任何一种数据库语言都可以分为三类语言。

一、DDL:数据库定义语言。是指对数据库结构进行定义、管理和调整的语言

二、DCL:数据库控制语言。是指对数据库的管理、访问权限进行定义、修改和调整的语言

三、DML:数据库操控语言。是指对数据库中的数据进行更新、查询的语言

这里书中的翻译是语言,但是我更倾向于用语句。因为在正常情况下,我们认为SQL是一种语言,而对于任何一个类似SQL的数据库语言,它基本都有上面三类语句。使用语言容易将这三种语句误解为和Sql平等地位的语言

事务管理

事务定义

事务是由一系列操作序列构成的程序执行单元。对于一个事务中的操作序列,要么都做,要么都不做,事务是一个不可分割的工作单位

事务特性

一、原子性:事务中包含的所有操作要么全做,要么全不做。他们必须是一个不可分割的工作单位

二、一致性:事务在处理前后整个数据库必须处于一致性的状态。即不同用户的数据库变化必须对应的上

三、隔离性:系统必须保证事务不受其他并发执行事务的影响

四、持久性:一个事务一旦提交后,他对数据库的影响必须是永久的

数据库系统结构

数据库系统的体系结构较为复杂,在后续章节详细带大家进入 

 数据库应用结构

数据库应用结构曾经是两层结构,此时应用(包括前端应用UI和后端应用业务逻辑)属于上层,一旦业务逻辑发生变化,UI前端需要发生变化,这将导致升级业务逻辑变得非常复杂。

现在的数据库应用结构都是三层结构,并且将应用分为应用客户和应用服务器。即将应用的前后端进行分离。此时应用的业务逻辑发生变化不需要再修改应用的前端UI。

综上数据库应用结构的改变,主要是应用上的改变,重点体现在应用的前后端分离

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/534997.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

罐头鱼AI短视频矩阵获客|AI视频批量生成

罐头鱼AI传单功能操作说明,智能化提升您的视频营销效率! 在这个信息爆炸的时代,短视频已成为企业营销的重要方式之一。而为了更高效地进行视频营销,罐头鱼AI传单功能应运而生,为您提供全方位的视频管理和发布服务。 首…

3d模型渲染成线条怎么办?---模大狮模型网

将3D模型渲染成线条效果通常可以通过以下几种方法实现,具体取决于你使用的建模软件或渲染器: 使用渲染器的线条渲染功能: 许多渲染器(如Blender的Cycles渲染器、Maya的Arnold渲染器等)提供了线条渲染功能。通过在渲染器设置中启用线条渲染选…

生产环境是Linux,日志不好查?自己开发一个下载日志功能页面

有时候甲方爸爸的项目要部署内网,日志不能直接copy&#xff0c;还是linux系统。排查日志很不方便。 自己搞一个日志下载功能&#xff0c;如果是分布式的项目&#xff0c;还能把其他项目的日志也一起copy下来&#xff0c;来看。 public BiStateDTO<Object> logList(Requ…

MAE预训练的VIT

MAE预训练的VIT&#xff0c;参考这篇文章&#xff1a;Segment Anything论文和源码解读 - 知乎

UI 学习 二 可访问性 模式

一 颜色对比 颜色和对比度可以用来帮助用户看到和理解应用程序的内容&#xff0c;与正确的元素交互&#xff0c;并理解操作。 颜色可以帮助传达情绪、语气和关键信息。可以选择主色、辅助色和强调色来支持可用性。元素之间足够的颜色对比可以帮助低视力的用户看到和使用你的应…

移速u盘怎么恢复彻底删除的文件,移速u盘彻底删除的文件如何恢复

移速u盘怎么恢复彻底删除的文件&#xff1f;在日常使用中&#xff0c;我们经常会遇到需要删除U盘中的文件的情况。然而&#xff0c;有时候我们可能会不小心将重要的文件彻底删除&#xff0c;导致数据的丢失。对于移速U盘用户来说&#xff0c;如何恢复彻底删除的文件成为了一个备…

源达财源滚滚:炒股决策助手,助力投资之路

在当今这个信息节奏飞快的金融市场&#xff0c;每位投资者都怀揣着对成功的渴望&#xff0c;渴望找到一款能够助力自己的炒股软件。他们深知&#xff0c;唯有借助先进的工具和技术、服务&#xff0c;才能更好地把握市场脉搏&#xff0c;实现财富梦想。 源达财源滚滚是一款聚合了…

深入挖掘C语言之——联合

目录 联合的定义 联合的特点 联合的应用场景 在C语言中&#xff0c;联合&#xff08;Union&#xff09;是一种特殊的数据结构&#xff0c;它允许在同一内存地址存储不同类型的数据。与结构体&#xff08;Struct&#xff09;不同的是&#xff0c;联合中的所有成员共享同一块内…

无缝集成 MongoDB Relational Migrator,Tapdata 提供关系型到 MongoDB 实时迁移优化方案

在去年的 MongoDB 用户大会纽约站上&#xff0c;MongoDB 正式宣布全面推出新工具 MongoDB Relational Migrator&#xff08;MongoDB RM&#xff09;&#xff0c;用以简化应用程序迁移和转换——即从传统关系型数据模型到现代的文档数据模型&#xff0c;助力组织快速提升运营效率…

深入解析Condition的底层实现原理

一、原理概述 在AQS中&#xff0c;存在两个FIFO队列&#xff1a;同步队列和等待队列。等待队列是由Condition内部实现的&#xff0c;是一个虚拟的FIFO单向队列。 释义&#xff1a; AQS中tali和head主要构成了一个FIFO双向的同步队列&#xff0c;AQS中Condition构成了一个FIFO…

数据结构中的平衡搜索树 --- 红黑树 (如何旋转与变色)

目录 红黑树的概念 红黑树的性质 红黑树节点的定义 红黑树的插入 1. 按照二叉搜索的树规则插入新节点 2. 检测新节点插入后&#xff0c;红黑树的性质是否造到破坏 红黑树的概念 红黑树&#xff0c;是一种二叉搜索树&#xff0c;但在每个结点上增加一个存储位表示结点的颜…

嵌入式学习38-数据库

数据库软件: 关系型数据库: Mysql &#xff08;开源&#xff09; Oracle SqlServer Sqlite &#xff08;小型数据&#xff09; 非关系型数据库&#xff1a;&#xff08;快速查找数据&#xff09; Redis NoSQ…