数据库基础理论知识

1.基本概念

  • 数据(Data):数据库存储的基本对象。数字、字符串、图形、图像、音频、视频等
  • 数据库(DB):在计算机内,永久存储、有组织、可共享的数据集合
  • 数据库管理系统(DBMS):管理数据库的系统软件
  • 数据库系统(DBS):DB+DBMS+DBA+DBAP

数据库系统的特点

  • 数据结构化
  • 数据的共享性高
  • 冗余度低,易扩充
  • 数据独立性高
  • 数据由DBMS统一管理和控制

2.三级模式两层映像

模式(schema)

对数据库中数据所进行的一种结构性的描述,是对视图的抽象

视图(view)/数据(data)

采用某种表现形式表现出来的数据库中的数据

三级模式

优点:使用户能按日常逻辑抽象地处理数据,而不必关心数据在计算机中的 表示和存储

两层映像

两个独立性

3.数据模型

  • 数据模型:数据结构+数据操作+完整性约束
  • 数据模型是对模式的抽象,模式是对数据的抽象
  • 三大经典数据模型:层次模型、网状模型、关系模型

关系模型示例

层次模型示例

网状模型示例

4.关系模型概述

  • 形象的说,一个关系就是一个表
  • 严格的说,笛卡尔积中具有某种意义的那些元组被称作一个关系
  • 关系模型三要素:数据结构,对数据的操作(关系运算),对数据的完整性约束

  • 关系运算:关系代数和关系演算。关系演算又分为:元祖演算和域演算
  • 由于关系的不同列的取值可能来自同一个域,为区分,需要为每一列起一个名 字,该名字即为属性名
  • 关系模式是关系的抽象

关系的特性

列是同质:即每一列中的分量来自同一域,是同一类型的数据

不同的列可来自同一个域,称其中的每一列为一个属性,不同的属性要给予 不同的属性名。

列位置互换性:表中的每列可以相互交换顺序,区分哪一列是靠列名

行位置互换性:区分哪一行是靠某一或某几列的值(候选码)

关系与表的区别:理论上,关系的任意两个元组不能完全相同。(集合的要求:集合内不能有 相同的两个元素),但现实应用中,表(Table)可能并不完全遵守此特性

关系模式中的完整性约束

实体完整性:关系的主码中的属性值不能为空值

参照完整性:如果关系R1的外码F与关系R2的主 码P相对应,则R1中的每一个元组的 F列的取值只有两种情况:①存在于R2的P列取值的集合② 空值

用户自定义完整性:用户自己定义的,对属性或属性组的值的约束条件

DBMS对关系完整性的支持

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

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

相关文章

数据结构:红黑树的模拟实现

目录 1、什么是红黑树? 2、红黑树的相关操作与实现 1、节点定义 2、查找操作 3、插入操作 1、cur为红,p为红,g为黑,cur存在且为红 2、cur为红,p为红,g为黑,u不存在/u存在且为黑 4、判断…

Prompt进阶3:LangGPT(构建高性能质量Prompt策略和技巧2)--稳定高质量文案生成器

Prompt进阶3:LangGPT(构建高性能质量Prompt策略和技巧2)–稳定高质量文案生成器 1.LangGPT介绍 现有 Prompt 创建方法有如下缺点: 缺乏系统性:大多是细碎的规则,技巧,严重依赖个人经验缺乏灵活性:对他人分享的优质 …

mysql基于mycat实现读写分离

试验环境 基于mysql主从复制已经实现 mycat主机192.168.199.149,安装好java和jdk 数据库主机192.168.199.150 数据库从机192.168.199.151 149配置 下载mycat并解压 vim /root/mycat/conf/server.xml vim /root/mycat/conf/schema.xml 150是主数据库&#xff0…

jenkins部署go应用 基于docker-compose

丢弃旧的的构建 github 拉取代码 指定go的编译版本 安装插件 拉取代码是排除指定的配置文件 比如 conf/config.yaml 文件 填写配置文件内容 比如测试环境一些主机信息 等 可以配置里面 构建的时候选择此文件替换开发提交的配置文件。。。。 编写docker-compose 文件 docker…

CountDownLatch介绍和使用

1. CountDownLatch是什么 CountDownLatch 是 Java.util.concurrent 包中的一个同步工具类,用于控制线程的执行顺序。它的主要作用是让一个或多个线程等待其他线程完成操作后再继续执行。 2. CountDownLatch 类常用方法 CountDownLatch(int count) 是 CountDownLa…

【C++ Boost库】原始计时器

文章目录 前言一、原始计时器1.1 timer定时器timer类的介绍异常安全代码概况 1.2 progress_timer类如何使用异常安全代码概况 1.3 progress_display类如何使用代码概况 总结 前言 在现代软件开发中,时间是一种不可逆转的资源。特别是在需要按时执行任务、调度事件或…

鸿蒙开发月薪过万,背后的秘密~

自从智联招聘公布出春节后首周的岗位需求数据后,鸿蒙开发岗位就被推上了热潮!鸿蒙相关职位数同比增长163%,投递人数同比增长349%,即分别增至去年同期的2.6倍、4.5倍,涨势突出。 于是我的朋友圈中就有人去市场中简单探…

mybatisplus使用基本步骤

1.设计实体类&#xff0c;给实体类加一些需要的注解 2.创建Service接口继承mybatisplus提供的 IService<实体类>接口 3.实现Service接口&#xff0c;并继承mybatisplus提供的 ServiceImpl<mapper接口&#xff0c;实体类>类 4.mapper接口继承mybatisplus提供的 B…

程序人生——Java中基本类型使用建议

目录 引出Java中基本类型使用建议建议21&#xff1a;用偶判断&#xff0c;不用奇判断建议22&#xff1a;用整数类型处理货币建议23&#xff1a;不要让类型默默转换建议24&#xff1a;边界、边界、还是边界建议25&#xff1a;不要让四舍五入亏了一方 建议26&#xff1a;提防包装…

数据结构——通讯录项目

1.通讯录的介绍 顺序表是通讯录的底层结构。 通讯录是将顺序表的类型替换成结构体类型来储存用户数据&#xff0c;通过运用顺序表结构来实现的。 用户数据结构&#xff1a; typedef struct PersonInfo {char name[12];char sex[10];int age;char tel[11];char addr[100]; }…

ai一键生成思维导图!这5款ai软件口碑爆棚!

从去年到现在&#xff0c;AI 人工智能经过一年多的发展普及&#xff0c;正逐渐被越来越多的人所接受和使用&#xff0c;它从最初的 AI 文本生成&#xff0c;逐步过渡到图片生成&#xff08;AI 绘画&#xff09;、思维导图 AI 生成&#xff08;AI 绘图&#xff09;、PPT 演示文稿…