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

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;然后在想…

通过Source insight查看内核源码

1.下载源码 https://www.kernel.org/pub/linux/kernel/ 下载后解压即可 2.打开SourceInsight,创建工程 点击顶部Project菜单 3.将源码文件导入工程 4.查看源码

蓝桥杯物联网例程下载

今年是蓝桥杯物联网的第一届 我也是赶快买了物联网的开发板 这是附带的例程和一些综合实验 仅供参考练习 里面所有的例程大概花了两周实现了大部分&#xff08;有一些例如ADC和PWM的 手头没有示波器和电压表就没有做&#xff09; 我比较懒 不喜欢做每个例程的教程 就统一分享出…

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

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

【汇编语言】王爽第六章程序6.3解答,8086汇编语言实现数据的倒序存放

程序很简单&#xff0c;就是利用栈&#xff0c;实现数据的倒序存放。 ; 将数据逆序存放 assume ds:data data segment dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h data endsassume ss:stack stack segmentdw 0,0,0,0,0,0,0,0 stack endsassume cs:code code segmen…

---------愿 青春与我皆不付---------------------

2019年8月4日晚 21点51 我愿以此用博客来记录我的学习之路 void mian(void) { while(1) { run(); } } 不负光阴 不负卿

【汇编语言】快速理解什么是寻址,什么是寻址方式

0 前言 有很多专业的资料讲述这些概念&#xff0c;但是&#xff0c;虽然很专业&#xff0c;但是初学者根本看不懂&#xff01; 因此在这里&#xff0c;我用最简单的方式&#xff0c;告诉你 什么是寻址什么是寻址方式 1 计算机的极简模型 计算机的世界中&#xff0c;只有二…

【汇编语言】程序设计过程,如何避免数据类型匹配错误?

真言&#xff1a;操作数据&#xff0c;先看方式&#xff0c;再对应解决 0 前言 对于x86系列的汇编语言&#xff0c;AT&T格式需要使用后缀指明操作数的数据类型&#xff0c;Intel格式并没有这样的规定&#xff0c;但是&#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;之后通过它来说明后面的知识。 …

初来乍到,多多关照。

从今天开始就要开始写博客了&#xff0c;把学到的知识都在这里记录下来&#xff0c;希望可以坚持&#xff0c;并且学到东西。

【MySQL】AUTO_INCREMENT只能应用于数值类型的列,且该列需要被索引

MySQL中的自动增量AUTO_INCREMENT&#xff0c;是有使用条件的 该列&#xff08;column&#xff09;的数据类型必须是数值型&#xff08;这点容易理解&#xff0c;数值才能自增&#xff09;该列必须被索引&#xff0c;比如定义为主键&#xff08;PRIMARY KEY&#xff09; 感悟…

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

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

利用SIGCHLD信号回收子进程

子进程执行结束之后&#xff0c;父进程如果不对其进行回收&#xff0c;子进程就会变为僵尸进程。 父进程可以通过调用wait()函数和waitpid()函数去回收子进程. 由于子进程结束时会发送SIGCHLD信号给父进程&#xff0c;不过此信号的默认动作为忽略&#xff0c;我们可以通过系统函…

【汇编语言】8086汇编语言的debug中,t和p命令的区别

单步跟踪命令&#xff08;单步进入(step in)&#xff09;&#xff1a;t命令是单步执行&#xff0c;是真的单步执行&#xff0c;碰到任何地方&#xff0c;都会一步步执行&#xff0c;遇到子程序&#xff0c;也会进入里面一步步执行再返回 单步执行命令&#xff08;单步通过(ste…

哲学家就餐问题(如何避免死锁)(多线程版)

哲学家就餐问题 多线程编程中&#xff0c;常常会遇到线程间访问共享资源的问题&#xff0c;如果处理不当则会发生死锁&#xff0c;某一个线程可能永远访问不到共享资源。 为了避免死锁的发生&#xff0c;提出哲学家就餐问题。 下面展示一些代码片段 #include <stdio.h>…

【汇编语言】汇编语言如何编程,如何避免出错

0 前言 这里以8086汇编语言举例。 1 重要方法&#xff1a;画流程图 这一点不再多说&#xff01;你懂的&#xff01;只要真的画流程图&#xff0c;并且按此翻译为汇编代码&#xff0c;程序出错几率就会减少很多。 2 框架思维&#xff1a;构建标准编程框架 这里只举例说明一…