【数据库】数据库基本概念:数据库管理系统 / 数据库 / 表 / 数据

0 前言

本文讲解数据库的最基本概念

推荐书籍:《MySQL 必知必会》
需要的软件:MySQL 8.0

1 数据库相关概念及其实战应用

1.1 数据(Data)

在人类世界中,数据可以是

  • 数值型数据
    • 十进制数
  • 非数值型数据
    • 图片
    • 声音
    • 视频
    • 文字
    • ……

在计算机世界中,数据是二进制数

映射
人类世界
计算机世界

将人类世界的信息,映射到计算机世界,将人类世界信息转换成二进制数,并且存储到计算机的过程,就叫数据的存储。

例如,你写一个博客,保存起来,这就是存储数据。

1.2 数据库(Database DB)

1.2.1 概念

数据的存储,需要使用容器,就好比水的存储,需要使用水桶一样,装数据的容器,就是数据库

在人类世界,装数据的容器,可以是文件柜
在这里插入图片描述
数据,就是文件,并且,通常情况下,文件是放在文件夹里的。

在这里插入图片描述
这里就引出了几个数据库学科中的重要概念

  • 数据库 —— 文件柜
  • —— 文件柜里的文件夹
  • 数据 —— 文件夹里的资料

这样,我想你能够明白,这几个概念之间的关系了。

值得注意的一点是,他们之间的关系,数据库与数据库,数据库中的表和表,表中的数据和数据,他们之间,都存在各种结构,也就是所谓的数据结构,这一点还是很重要的,但是现在先不谈这个事情。

1.2.2 实战

我们来用MySQL的命令,演示一下。

1.2.2.1 显示数据库

显示数据库:show databases;
在这里插入图片描述
它在资源管理器中,就是文件夹,我们来看一下
在这里插入图片描述
我展示出了路径,你可以自己找一下,默认C盘,可以看出,数据库名称与文件夹名称之间是对应的

1.2.2.2 创建数据库

创建数据库:create database <数据库名称>;

我们将数据库的名字命名为FileCabinet(文件柜)好了。
在这里插入图片描述
我们再查看一下数据库
在这里插入图片描述
你可以看见文件夹也有了这个
在这里插入图片描述
不过,不知道有没有注意到,为什么是小写了?

原因在于:MySQL在windows下,不区分大小写,但是在Linux下区分大小写,所以,为了能够更容易匹配,就全部转换为小写。

1.2.2.3 使用数据库

使用数据库:use <数据库名称>;
在这里插入图片描述
这样,你就能够使用这个数据库了,比如可以在里面创建表,再创建文件,等等。

1.2.2.4 显示当前数据库中的表

指令:show tables;
在这里插入图片描述
结果显示,这个数据库中,没有表,是空的,这也就是说,文件柜是新生产的,里面啥都没有。

1.2.2.5 在数据库中创建表

语法:create table <表的名字> (表的定义);
在这里插入图片描述
这里设计到SQL语言的数据类型,先不用管,只需要知道

  • 我们在数据库filecabinet中创建了一个表,名字叫student_file
  • 表的定义部分,也就是()中的,带表:这个表中的数据,可以具备两个属性,一个是字符类型的name,一个是数字类型的age

1.2.2.6 查看刚刚创建的表

命令:show tables;
在这里插入图片描述
我们可以看见,在这个数据库中,我们拥有了一个名字为student_file的表。我们还可以按照上一小节的内容,在该数据库中,创建更多的表。

我们进入资源管理器中,看一下我们创建的表。
在这里插入图片描述
在文件夹filecabinet中,创建了一个ibd类型的文件,这也就是我们创建的表对应的文件。

1.2.2.7 表的定义是什么意思?

刚刚我们提到了表的定义,和表的两个属性,name和age,那么,他们到底是什么意思?

举一个例子你就明白了,你在学习工作中,是不是总要填表格

我们现在创建一个Excel表格,将其命名为student_file
在这里插入图片描述
然后,在表格内,写上一些内容
在这里插入图片描述
并明确要求,name一栏,要写字符型数据,age一栏,要写数字,之后让同学们填写。
在这里插入图片描述
这样一来

  • 张三、李四和王五,写在了name一栏,并且是char类型的数据
  • 18、19和20,写在了age一栏,并且是int类型的数据

这也就是说,我们的student_file,具备两个属性char类型的nameint类型的age,并且可以在里面填写符合标准的信息

这也就是所谓表定义的意义它指明了整个表能够填入什么样的数据

1.2.2.8 其他

后续还有表内数据的填写等等,以后再说。

1.2.3 小结

我们来总结一下本小节的重要内容:数据管理系统、数据库、表和数据,理清他们之间的逻辑关系。

对于一片计算机存储空间,可以创建多个数据库创建的数据库需要有<名称>,在资源管理器中,表现为创建了多个文件夹
在这里插入图片描述
对于每一个数据库,内部都可以创建多个表创建的表需要有<名称>和(属性),在资源管理器中,体现为在数据库文件夹内,创建多个文件。
在这里插入图片描述
对于每一个表,表内包含了符合其属性的数据,在资源管理器表现为,表对应的文件中的内容
在这里插入图片描述
DBMS,就是能够方便管理数据库、表、数据的软件。
在这里插入图片描述

补充:与计算机组成原理联系,可以将DBMS看成CPU的控制器,掌控着各个器件的运行方式。

1.3 数据库管理系统(Database Management System DBMS)

DBMS,就是方便人类操作数据库的软件,比如MySQL,SQL Server等等,都是数据库管理系统,都是软件,上一小节我们使用的各种指令,就是在MySQL软件上进行的。

还有一个概念:数据库管理员(Database Administrator DBA)

DBA,就是管理数据库管理系统的人,你可以理解为,图书馆管理员,他需要管理整个图书馆的各个书柜,书柜也就是数据库。

1.4 数据库系统(Database System DBS)

重点不是数据库管理系统,而是系统,我们知道很多系统,比如计算机系统,选课系统……谈及系统,必须要谈及其所在的层次,他代表其所在层次领域的全部生态

例如数据库系统,他就包含

  • 数据库管理系统
  • 数据库管理员
  • 数据库
  • 数据
  • 用户

等等,整个数据库学科生态的全部内容,及其结构关系,甚至还有包含其与外界的联系,系统是个很复杂的事情,你这样简单理解就可以了。

DBS
DBA
应用系统/用户等
DBMS
DB
TABLE
DATA

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

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

相关文章

tiny4412初期环境搭建

花了整整三天 从跃跃欲试到失望 绝望 最后迎来曙光!!! 话不多说直接上干货 这些软件安装的具体过程网上有很多 在这里就不说了 1.在主机下 安装secureCRT软件和超级终端&#xff08;安一个就行 不过最好两个都安上&#xff09; 作用&#xff1a; 软件可以打印一些开发板信息…

vivado软件如何查看内部器件的仿真信号

有时候&#xff0c;我们需要查看内部模块的信号&#xff0c;那么&#xff0c;在vivado软件该如何操作呢&#xff1f; 运行仿真&#xff0c;可以得到这个界面&#xff0c;之后看左侧部分&#xff0c;可以查看内部的模块。 例如单击rom0 可以看见其内部信号&#xff0c;然后在想…

Vivado软件(用VerilogHDL)如何使用$readmemh和$readmemb函数

0 前言 博主我查了很多资料&#xff0c;虽然会使用Verilog的readmemh和readmemh和readmemh和readmemb函数&#xff0c;可是&#xff0c;在vivado软件中怎么用&#xff1f;文件放在哪里&#xff1f;没有一篇文章提及。 花了几个小时&#xff0c;终于研究明白了&#xff0c;特此…

【汇编语言】王爽实验5(5)(6)的解答 建立数据类型匹配的观念

0 前言 本文解答王爽《汇编语言》实验5的&#xff08;5&#xff09;&#xff08;6&#xff09;题 同时给出一些常见问题的解答 以及给出最易犯错的地方&#xff1a;数据类型不匹配的解决方案 1 题目解答 1.1 实验5&#xff08;5&#xff09; 1.1.1 题目 将data1和data2段…

【Java图文趣味版】快速搞定数组的声明、开辟空间和初始化赋值

0 前言 本文讲解java数组的基础知识&#xff0c;适合零基础小白。 1 数组的概念 所谓数组&#xff0c;就是一组同类型东西的集合&#xff0c;可以通过index&#xff08;索引&#xff0c;下标&#xff09;访问这一组东西的某一个元素。 就像下图这样&#xff0c;由于数组概念…

【java图文趣味版】数组元素的访问与遍历

0 前言 本文适合零基础小白。 本文接上一篇文章&#xff1a;快速搞定数组的声明、开辟空间和初始化赋值 重要的知识点 通过array index访问数组使用for each循环遍历数组使用Arrays.toString()方法打印数组 我们先创建一个数组&#xff0c;之后通过它来说明后面的知识。 …

【数据库】数据模型基础概念(图文版)

0 前言 本文通过一个实例&#xff0c;来讲解数据模型的基础概念。 要求设计一个数据库的数据模型&#xff0c;统计出你的宿舍每个人&#xff08;4个人&#xff09;的信息&#xff0c;要求包括 个人信息&#xff1a;学号、姓名、班级、年级、学院选课情况&#xff1a;学号、课程…

哲学家就餐(避免死锁)(多进程版)

哲学家就餐&#xff08;避免死锁&#xff09;&#xff08;多进程版&#xff09; 哲学家就餐利用信号量在多进程之间实现 下面展示一些代码片段 #include <stdio.h> #include <unistd.h> #include <stdlib.h> #include <sys/wait.h> #include <sys…

【汇编语言】数据类型的匹配问题:自动匹配与手动匹配

0 前言 本文基于8086汇编语言&#xff0c;不过x86系列语言具备向下兼容特点&#xff0c;大多数情况都可以用。 与高级语言数据类型的自动转换和强制转换一样&#xff0c;汇编语言的数据类型也有 自动匹配和手动匹配。 下面&#xff0c;我来介绍一下汇编语言的相关原则。 1 …

Qt制作定时关机小程序

文章目录 完成效果图ui界面ui样图 main函数窗口文件头文件cpp文件 引言 一般定时关机采用命令行模式&#xff0c;还需要我们计算在多久后关机&#xff0c;我们可以做一个小程序来定时关机 完成效果图 ui界面 <?xml version"1.0" encoding"UTF-8"?>…

Visual Studio 编译优化选项:Debug与Release、禁止优化与O1、O2、Ox优化

Debug与禁止优化 Debug模式是调试模式&#xff0c;会有很多冗余的调试代码&#xff0c;供开发者调试程序使用。 VS是默认使用Debug模式的&#xff0c;我使用的是VS 2017。 在Debug模式下&#xff0c;是默认开启禁止优化的&#xff0c;我们来查看一下 在左侧源文件的main.c处…

【数字逻辑入门】计算机如何存储1位二进制数

0 前言 本文将会以R-S锁存器为例&#xff0c;引出锁存器的核心和本质&#xff0c;之后再带你构建更多类型的锁存器&#xff0c;你能够&#xff1a; 感受到由浅入深的学习方式体会到掌握核心本质的快感深刻理解核心套外壳的设计理念&#xff08;产品迭代1.0–>2.0–>3.0…

【算法训练】DAY1:整数反转

1 前言 题目来源于Leetcode。 重点&#xff1a;理清逻辑&#xff0c;忽略细节&#xff0c;模仿高手&#xff0c;五毒神掌 2 题目分析 题目很容易理解&#xff0c;先分成两个部分 正数负数 先解决正数 最开始想到的是 intchar数组long唯一增加的就是&#xff0c;先判断整…

【蓝桥杯】BASIC-8 回文数(2020-06-08)

题目 试题 基础练习 回文数 资源限制 时间限制&#xff1a;1.0s 内存限制&#xff1a;512.0MB 问题描述   1221是一个非常特殊的数&#xff0c;它从左边读和从右边读是一样的&#xff0c;编程求所有这样的四位十进制数。    输出格式   按从小到大的顺序输出满足条件的…

【算法训练】Leetcode 1295. 统计位数为偶数的数字(2020.06.09 )

1 题目 1295. 统计位数为偶数的数字 给你一个整数数组 nums&#xff0c;请你返回其中位数为 偶数 的数字的个数。 示例 1&#xff1a; 输入&#xff1a;nums [12,345,2,6,7896] 输出&#xff1a;2 解释&#xff1a; 12 是 2 位数字&#xff08;位数为偶数&#xff09; 345 …

Vivado设置指定源文件进行RTL优化

像VS编译器设置启动项一样&#xff0c;Vivado中&#xff0c;也有类似设计&#xff0c;可以看到&#xff0c;当前选中的是ALU&#xff0c;那么进行RTL优化的时候&#xff0c;会优化RTL的结果&#xff0c;而不是别的&#xff0c;如何改成别的&#xff1f; 在某文件上右键单击选择…

【完整流程】用VSCode替换Vivado默认编辑器

本文楼主找了很多资料&#xff0c;选出了最有用的资料&#xff0c;按照教程走&#xff0c;就可以顺利搞定&#xff0c;先给出画面 很酷很方便&#xff0c;同时还有 自动补全检测错误列选自动生成仿真测试文件 等重要功能 Vivado原来的编辑器是这样的…… 关键是&#xff0c…

IEDA中JavaDoc的自动生成、手动生成,以及生成html文档

1 自动生成类的注释 JavaDoc就是java特有的一种注释。 1.1 配置 首先&#xff0c;IDEA点击File-->Settings 然后Editor-->File and Code Templates-->Class 之后在这地方&#xff0c;添加一些代码 /** * ${description} * * <p> * 创建日期&#xff1a;$…

【java】父类与子类的引用赋值关系

理清楚4个目标 父类引用&#xff08;“名”&#xff09;父类对象&#xff08;“实”&#xff09;子类引用子类对象 理清楚几个操作 // 父类 public class parent{}// 子类 public class sun{}父类引用指向父类对象 parent p1 new parent();子类引用指向子类对象 son s1 …