初识MySQL · 数据库

目录

前言:

数据库

简单使用 + 存储引擎


前言:

本文也是MySQL的第一篇文章了,新的知识点已经出现,怎么能够停止不前,穿越时空……(迪迦奥特曼乱入哈哈哈)。

言归正传,我们在本文的目标有:

1 什么是数据库 2 主流数据库有哪些 3 MySQL的基本使用 4 MySQL的基本架构 5 存储引擎

进入正题吧!


数据库

首先提问,按照常理来说,什么是数据库呢?

不少人想到的一点就是,不就是数据的集合吗?是的,数据库从数据存储方面确实只是数据的集合,但是数据库不只是为了集合数据而存在。

如果是为了集合数据,像我们磁盘中任意的文件,本质上也是集合数据:

这是一种集合数据。

集合完数据之后我们应该干什么呢?单纯为了集合数据肯定不行,我们应该需要某个东西/软件来管理我们的数据,方便我们可以在日常使用,或者是程序处理问题的时候更加方便,效率更高,这个时候,数据库就闪亮登场了。

没错,我们学习的MySQL本质上就是数据库,给我们提供了数据存储的功能以外,还可以提供数据的各方面管理。

那么,提问,我们使用ubuntu登录到MySQL的时候,可是看到了两个东西的:

一个是mysql一个是mysqld,它们所在的目录分别为:

它们是什么关系呢?

这里不卖关子了,mysql是数据库服务的客户端,mysqld是数据库服务的服务端,而我们使用指令netstat也是可以查到mysql的,所以得出结论,是什么

mysql实际上是一种网络服务,而且是一种基于C(mysql)S(mysqld)的网络服务。

那么服务的是什么呢?服务的是数据存取。

所以数据库是:在磁盘或者是内存中以特定结构组成而成的数据,那么数据库服务就是mysqld

那么又是如何服务的呢?

给某种特定的要求,或者某种特定的字段,mysqld直接给结果就可以了。

所以数据库的本质是:对数据内容处理的一种解决方案

以上是对数据库的一些基本理解,我们上文提及的,数据库不只是有一个,目前主流的数据库有的如下:

SQL Sever: 微软的产品,.Net程序员的最爱,中大型项目。

Oracle: 甲骨文产品,适合大型项目,复杂的业务逻辑,并发一般来说不如MySQL。

MySQL:世界上最受欢迎的数据库,属于甲骨文,并发性好,不适合做复杂的业务。主要用在电 商,SNS,论坛。对简单的SQL处理效果好。

PostgreSQL :加州大学伯克利分校计算机系开发的关系型数据库,不管是私用,商用,还是学术研 究使用,可以免费使用,修改和分发。

SQLite: 是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。

 H2: 是一个用Java开发的嵌入式数据库,它本身只是一个类库,可以直接嵌入到应用项目中。

那么具体的差异就交给同学们自己查阅了,因为MySQL是免费的,所以我们用它来介绍sql语句,而我们有了该数据库的基础,学习其他数据库起来也是十分轻松的了。

而对于MySQL来说,数据库肯定和表拉不开关系,那么对于表的上一层是DB,也就是Database,数据库,对于程序员来说,一般来说都会为不同的软件专门分配不同的数据库,多个数据库中又会创建不同的表,用来保存数据。

这是MySQL,Database,表的基本关系。

说了那么多,我们来简单使用一下。


简单使用 + 存储引擎

我们先登入到MySQL上面:

现在我们MySQL里面有没有数据库我们是不知道的,我们应该先看看,所以show databases:

这里和我们平常使用Linux的命令行有所不同是,我们提供的字段是需要加;的,所以是show databases;

那么我们发现我们目前有的数据库是那4个,我们先不管,先自己添加一个数据库试试:

此时提示创建成功,我们重新看看:

不出意外的话,数据库是多了一个,我们最开始也提到了,

我们使用root权限(注意,这里使用普通用户是进不去的),切换到了root之后,我们进入到/var/lib/mysql,可以发现里面的内容,目录好像有几个是我们才看到的?

那么我们是否可以认为,建数据库的过程就是建立目录的过程呢

答案:是!数据库本质上就是一个一个的目录。

这是一个新认识,那么我们不妨看看我们的数据库里面都有什么:

ubuntu环境下是什么也没有的,但是在Centos的环境下,存在文件dp.opt,里面存储的就是对应的编码格式。

现在,返回到MySQL:

现在我们已经成功切换到了test_mysql里面,那么前文提及,数据库里面都是有表的,所以我们不妨创建一张表:

这里的语法和之前学习Linux或是C++的差别还有点大,所以得多练习。

那么表有了,我们总得插入几个数据吧?

使用指令insert into ...,注意,这里使用的引号用了单引号和双引号,那么使用是否有差别呢?我们后面提及。

此时数据插入完毕,我们使用指令:

select * from student;

成功查询到了我们刚才插入的所有数据。

那么在数据库里面的列和行和平常意义的都是一样的。

这是最最基本的使用。

现在我们来看看MySQL的架构部分,对于最上层的肯定是客户端,我们主要是关系存储引擎部分。

这个存储引擎的特点是热插拔,就像我们平常写了一个类,需要用的时候实例化一个对象就可以了,用完删除即可,这个也是,用的时候激活即可。

MySQL中的存储引擎是数据库管理系统的核心组成部分,它负责数据的存储、检索以及处理。每个存储引擎都有其特定的设计理念和性能特点,常见的就是上面的。

但是实际上平常用的多的也就是InnoDB, MyISAM,具体我们放在后面介绍,这里作为了解即可。 

那么我们查看存储引擎就是show engines:

而我们看Support那一行,InnoDB是default,也就是默认打开的,也可以看出它十分的常用。

以上是对MySQL的粗略介绍,如有不足,请多多指正! 


感谢阅读!

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

基于SpringBoot+Vue+uniapp的涪陵区特色农产品交易系统的详细设计和实现(源码+lw+部署文档+讲解等)

详细视频演示 请联系我获取更详细的视频演示 项目运行截图 技术框架 后端采用SpringBoot框架 Spring Boot 是一个用于快速开发基于 Spring 框架的应用程序的开源框架。它采用约定大于配置的理念,提供了一套默认的配置,让开发者可以更专注于业务逻辑而不…

MATLAB(Octave)混电动力能耗评估

🎯要点 处理电动和混动汽车能耗的后向和前向算法模型(simulink),以及图形函数、后处理函数等实现。构建储能元数据信息:电池标称特性、电池标识符等以及静止、恒定电流和恒定电压等特征阶段。使用电流脉冲或要识别的等效电路模型类型配置阻抗…

day-13面向对象进阶

面向对象进阶部分学习方法: 特点: ​ 逻辑性没有那么强,但是概念会比较多。 ​ 记忆部分重要的概念,理解课堂上讲解的需要大家掌握的概念,多多练习代码。 day13 第一章 复习回顾 1.1 如何定义类 类的定义格式如…

Linux_进程控制

一&#xff1a;进程创建 fork()函数创建新进程 #include <unistd.h> pid_t fork(void); 返回值&#xff1a;自进程中返回0&#xff0c;父进程返回子进程id&#xff0c;出错返回-1 进程调用fork&#xff0c;当控制转移到内核中的fork代码后&#xff0c;内核做&#xff1a;…

KubeSphere部署Elasticsearch+Kibana

演示示例使用的是3.4.1&#xff0c;各版本有名字差异 功能是一样的 1.配置字典 名称&#xff1a;elasticsearch 键名&#xff1a;elasticsearch-conf 值&#xff1a; network.host: 0.0.0.0 http.port: 9200 transport.port: 9300 # head 插件需要这打开这两个配置,解决跨域…

面试:了解 ThreadLocal 内存泄漏需要满足的 2 个条件吗?

欢迎关注公众号 【11来了】&#xff08;文章末尾即可扫码关注&#xff09; &#xff0c;持续 中间件源码、系统设计、面试进阶相关内容 在我后台回复 「资料」 可领取 编程高频电子书&#xff01; 在我后台回复「面试」可领取 30w 字的硬核面试笔记&#xff01; 感谢你的关注&…

Vim工具使用( Linux 网络操作系统 07)

1 概念部分 vim是vimsual interface的简称&#xff0c;它可以执行输出、删除、查找、替换、块操作等众多文本操作&#xff0c;而且用户可以根据自己的需要对其进行定制。这是其他编辑程序所没有的。vim不是一个排版程序&#xff0c;它不像Word或WPS那样可以对字体、格式、段落…

记录 ruoyi-vue-plus在linux 部署遇到的问题

整理 linux 文件不要放在 /, 根目录下&#xff0c;要放在 home 文件夹下。docker 启动mysql 容器&#xff0c;映射的 my.cnf 文件不能设置太高权限&#xff0c;权限太高有安全问题&#xff0c;无法读取。 linux 使用注意事项 docker 文件夹 部署在home文件夹下 总结学习到的…

linux的随机化处理

Linux的随机化处理&#xff08;或称为地址空间布局随机化&#xff0c;ASLR&#xff09;是一种安全特性&#xff0c;旨在提高系统对抗攻击的能力&#xff0c;尤其是缓冲区溢出和代码注入攻击。随机化处理通过改变进程在内存中的布局来减少攻击者利用漏洞的可能性。 随机化处理的…

SOLIDWORKS参数化软件

在产品设计和工程领域&#xff0c;参数化设计是一种革命性的方法&#xff0c;它允许设计者通过定义一系列规则和关系来创建和修改模型。参数化设计的核心在于将设计过程分解为一系列可调整的参数&#xff0c;如尺寸、形状、材料属性等&#xff0c;这些参数之间通过数学关系相互…

【北京迅为】《STM32MP157开发板嵌入式开发指南》- 第四十九章 平台总线总结回顾

iTOP-STM32MP157开发板采用ST推出的双核cortex-A7单核cortex-M4异构处理器&#xff0c;既可用Linux、又可以用于STM32单片机开发。开发板采用核心板底板结构&#xff0c;主频650M、1G内存、8G存储&#xff0c;核心板采用工业级板对板连接器&#xff0c;高可靠&#xff0c;牢固耐…

Anaconda虚拟环境安装cuda和pytorch

首先电脑上要有Anaconda&#xff0c;使用conda创建一个虚拟环境,并激活 conda create yolov8 conda activate yolov8winR输入cmd&#xff0c;在命令窗口输入 NVIDIA-smi可以查看到自己电脑支持的cuda环境&#xff0c;如下图 再打开torch的官网 pytorch官网 查看目前支持的版…

C++ MFC 标准库 加密解密解惑

&#x1f3c6;本文收录于《全栈Bug调优(实战版)》专栏&#xff0c;主要记录项目实战过程中所遇到的Bug或因后果及提供真实有效的解决方案&#xff0c;希望能够助你一臂之力&#xff0c;帮你早日登顶实现财富自由&#x1f680;&#xff1b;同时&#xff0c;欢迎大家关注&&am…

第五届光学与图像处理国际学术会议(ICOIP 2025)征稿中版面有限!

第五届光学与图像处理国际学术会议&#xff08;ICOIP 2025&#xff09; 2025 5th International Conference on Optics and Image Processing (ICOIP 2025&#xff09; 重要信息 时间地点&#xff1a;2025年4月25-27日丨中国西安 截稿日期&#xff1a;2024年12月16日23:59 …

Java项目-基于Springboot的应急救援物资管理系统项目(源码+说明).zip

作者&#xff1a;计算机学长阿伟 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、ElementUI等&#xff0c;“文末源码”。 开发运行环境 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringBoot、Vue、Mybaits Plus、ELementUI工具&#xff1a;IDEA/…

【数据结构与算法】力扣 54. 螺旋矩阵

问题描述 给你一个 m 行 n 列的矩阵 matrix &#xff0c;请按照 顺时针螺旋顺序 &#xff0c;返回矩阵中的所有元素。 示例 1&#xff1a; 输入&#xff1a; matrix [[1,2,3],[4,5,6],[7,8,9]] 输出&#xff1a; [1,2,3,6,9,8,7,4,5]示例 2&#xff1a; 输入&#xff1a; ma…

【C++】deque(空间适配器))

适配器 适配器是一种设计模式(设计模式是一套被反复使用的、多数人知晓的、经过分类编目的、代码设计经验的总结)&#xff0c;该种模式是将一个类的接口转换成客户希望的另外一个接口。 STL标准库中stack和queue的底层结构 deque原理介绍 deque(双端队列)&#xff1a;是一种…

Visual Studio2022 无法打开源文件

今天在新电脑上安装了Visual Studio2022&#xff0c;但是无法打开多个源文件&#xff0c;网上搜索都是说重新安装Windows SDK 我最开始安装的sdk版本是win11SDK 修改成其他版本后也没有解决问题 最后安装了Windows 10 SDK 10.0.20348.0 这个版本&#xff0c;成功解决问题。 有…

快速了解kubernetes中的存储管理

目录 一 configmap 1.1 configmap的功能 1.2 configmap的使用场景 1.3 configmap创建方式 1.3.1 字面值创建 1.3.2 通过文件创建 1.3.3 通过目录创建 1.3.4 通过yaml文件创建 1.3.5 configmap的使用方式 1.3.5.1 使用configmap填充环境变量 1.3.5.2 通过数据卷使用c…

大数据-173 Elasticsearch 索引操作 增删改查 详细 JSON 操作

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff08;已更完&#xff09;HDFS&#xff08;已更完&#xff09;MapReduce&#xff08;已更完&am…