与MySQL的初相遇

🌎初识MySQL

:本文SQL语句只为了验证猜想,不会也不要紧。

文章目录:

MySql开端

    认识数据库
      什么是数据库
      主流数据库
      MySQL的本质

    MySQL基础使用
      连接mysql服务器
      MySQL与文件的关系
      服务器管理
      服务器、数据库和表关系

    MySQL架构

    SQL语句分类


前言
  MySQL是地表最受欢迎开源的数据库管理系统之一,也作为程序员水平的技术之一。今天我们就开始全新的话题!

在这里插入图片描述


🚀认识数据库

✈️什么是数据库

存储数据用文件就可以了,为什么还要弄个数据库?
文件保存数据有以下几个 缺点

  • 文件的安全性问题
  • 文件不利于数据查询和管理
  • 文件不利于存储海量数据
  • 文件在程序中控制不方便

数据库存储介质:

  • 磁盘
  • 内存

  为了解决上述问题,专家们设计出 更加利于管理数据的东西——数据库,它能更有效的管理数据。数据库的水平是衡量一个程序员水平的重要指标。


✈️主流数据库
  • SQL Sever: 微软的产品,.Net程序员的最爱,中大型项目。
  • Oracle: 甲骨文产品,适合大型项目,复杂的业务逻辑,并发一般来说不如MySQL。
  • MySQL:世界上最受欢迎的数据库,属于甲骨文,并发性好,不适合做复杂的业务。主要用在电商,SNS,论坛。对简单的SQL处理效果好。
  • PostgreSQL:加州大学伯克利分校计算机系开发的关系型数据库,不管是私用,商用,还是学术研究使用,可以免费使用,修改和分发。
  • SQLite: 是一款轻型的数据库,是遵守ACID的关系型数据库管理系统,它包含在一个相对小的C库中。它的设计目标是嵌入式的,而且目前已经在很多嵌入式产品中使用了它,它占用资源非常的低,在嵌入式设备中,可能只需要几百K的内存就够了。
  • H2: 是一个用Java开发的嵌入式数据库,它本身只是一个类库,可以直接嵌入到应用项目中。

✈️MySQL的本质

  MySQL事实上是一种网络服务,我们使用的是Linux下的mysql服务,在Linux下使用grep命令可以查看:

在这里插入图片描述

  其中,mysql是数据库服务的客户端,mysqld是数据库服务的服务器端,而mysql的本质,基于 C(mysql) S(mysqld) 模式的一种网络服务

  而mysql作为一种网络服务,在Linux下,我们就一定能使用如下命令来监测出mysql的网络服务:

netstat -lntp

在这里插入图片描述
  话虽如此,但mysql可不仅仅是一套服务,它还是一套给用户提供数据存取服务的网络程序。可以在服务端对数据进行保存。

  而我们口头所说的 “数据库”一般指的是,在磁盘或内存中存储存储特定结构组织的数据,也就是在磁盘上存储的一套数据库方案


🚀MySQL基础使用

✈️连接mysql服务器

  不论在Linux下还是Windows下连接MySQL都需要先下载MySQL服务器。在MySQL中,我们使用如下命令连接MySQL:

mysql -P 3306 -h 127.0.0.1 -u root -p

  其中各个选项的含义如下:

  • -P选项表示mysql端口号,通常为3306。不带此选项默认为3306端口
  • -h选项表示要连接mysql主机,本机为127.0.0.1。不带这个选项默认是本机连接
  • -u选项表示哪个用户登录mysql。
  • -p选项password,表示用户登录密码。
  • root用户表示以root的身份登录mysql。

在这里插入图片描述
  当看到此页面时,就表示你已经登录MySQL成功了,进入到MySQL中想退出怎么办呢?输入 quit; 再回车即可退出MySQL:

在这里插入图片描述


✈️MySQL与文件的关系

  首先,在MySQL中存在一个个的库,而我们想要查看这些库,可以使用如下SQL命令:

SHOW DATABASES;--大小写随意--

在这里插入图片描述

  我们发现MySQL中默认存在四个库、那么这四个库存储在系统的哪个位置呢?通常在MySQL中/etc目录下的配置文件中查看:

cat /etc/mysql/mysql.conf.d/mysqld.cnf #很多不确定性因素,你的可能和我的配置文件不同

  而在该文件下,一般都会保存一个名为 datadir 的目录,是用来保存SQL服务所对应的数据:

在这里插入图片描述

  我们进入到所保存的目录,为了验证以上说法,我们首先创建一个数据库,使用如下SQL指令:

CREATE DATABASE helloMySQL;--创建名为helloMySQL的数据库--

在这里插入图片描述

  我们发现确实如此,当然不仅如此,细心的小伙伴已经发现别的端倪了。而我们查看刚刚创建的这个目录:

在这里插入图片描述
  我们发现这里什么都没有,当然你的可能会有 dp.opt 默认配置文件。所以由此我们可以得出结论:所谓建立数据库,本质就是在Linux下创建一个目录文件

  而我们关系型数据库也得有表来展示,我们不妨使用如下SQL语句创建一张数据表:

USE helloMySQL;--使用具体的数据库--
CREATE TABLE student(id int,name varchar(32),gender varchar(2)
);

在这里插入图片描述
  这样我们的表就创建成功了。而这个时候我们在Linux下对该目录进行查看时:

在这里插入图片描述

  此时在该目录下就多了一个后缀为 .ibd 的文件了。创建完表当然要对表插入数据,我们使用如下的SQL语句对该表进行插入:

insert into student (id, name, gender) values (1, '张三', '男');
insert into student (id, name, gender) values (2, '李四', '女');
insert into student (id, name, gender) values (3, '王五', '男');

在这里插入图片描述
  这样就插入成功了,我们使用如下SQL语句查看刚插入的表结构:

select * from student;

在这里插入图片描述

  而我们输入这些SQL语句才完成了这样的工作,那么这个工作真的是我们完成的吗?实际上 这个工作是由mysqld来完成的!我们只是给它发了指令而已!他们的关系如下:

在这里插入图片描述


✈️服务器管理

  如果你是 windows 下的MySQL用户,我们可以通过 win + r 并输入 services.msc 快速打开文件夹模式来 停用或者暂停 MySQL服务:

在这里插入图片描述


✈️服务器、数据库和表关系
  • 所谓安装数据库服务器,只是在机器上安装了一个数据库管理系统程序,这个管理程序可以管理多个数据库,一般开发人员会针对每一个应用创建一个数据库
  • 为保存应用中实体的数据,一般会在数据库中创建多个表,以保存程序中实体的数据

  而数据库服务器、数据库和表的关系如下:

在这里插入图片描述
  准确来说,Client实际上是mysqlMySQL实际上是mysqld后面的内容俗称 “数据库”,而各个表其实就是普通的文件,只不过表的文件是以二进制形式存储的。


🚀MySQL架构

  MySQL 是一个可移植的数据库,几乎能在当前所有的操作系统上运行,如Unix/Linux、Windows、Mac 和 Solaris。各种系统在底层实现方面各有不同,但是 MySQL 基本上能保证在各个平台上的物理体系结构的一致性。

在这里插入图片描述

  虽然上面划分了四层结构,但是对于整体的MySQL Serve来说,主要功能由前三层来构成。

  • 链接池(Connection Pool)其作用是帮助用户做网络管理、帮助用户做鉴权和保证一些安全方面的策略

  • 中间层处理下达的一些SQL指令,而MySQL要对下达的SQL语句做词法分析、语法分析、甚至对SQL查询进行优化,随后按照SQL的协议将SQL传入下一层

  • 可插拔存储引擎(Pluggable Storage Engines)底层的存储引擎将上层经过处理的SQL语句,对其进行解释工作。访问指定数据库、访问指定文件、表结构等,对数据进行增删查改

  存储引擎是:数据库管理系统如何存储数据、如何为存储的数据建立索引和如何更新、查询数据等技术的实现方法。MySQL的核心就是插件式存储引擎,支持多种存储引擎。

我们可以使用如下SQL指令查看存储引擎:

SHOW ENGINES;

在这里插入图片描述

以下是一些存储引擎的对比:

在这里插入图片描述


🚀SQL语句分类

  • DDL[data definition language] : 数据定义语言,用来维护存储数据的结构代表指令: create, drop, alter
  • DML[data manipulation language]: 数据操纵语言,用来对数据进行操作代表指令: insert,delete,update
  • 数据查询语言为DML中单独分了一个DQL,代表指令: select
  • DCL[Data Control Language]: 数据控制语言,主要负责权限管理和事务代表指令: grant,revoke,commit

  今天的内容到这里就结束啦,如果这篇文章对您有帮助的话,还望给点个小赞~~

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

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

相关文章

自动化您的任务——crewAI 初学者教程

今天,我写这篇文章是为了分享您开始使用一个非常流行的多智能体框架所需了解的所有信息:crewAI。 我将在这里或那里跳过一些内容,使本教程成为一个精炼的教程,概述帮助您入门的关键概念和要点 今天,我写这篇文章是为了…

easy-rule规则引擎使用

简介 轻量级的规则引擎&#xff0c;易于学习的api 简单来说&#xff0c;规则引擎就是一个函数&#xff1a;yf(x1,x2,…,xn) 将业务代码和业务规则分离&#xff0c;解耦业务决策和业务代码的绑定关系 入门示例 依赖引入 <dependency><groupId>org.jeasy</grou…

页面<html>上多了一个滚动条,定位发现是<body>里面多了一个id为trans-tooltip的div

现象分析&#xff1a; 页面根标签html多了一个滚动条&#xff0c;发现body里面多了一个id为trans-tooltip的div&#xff0c;虽然width为0&#xff0c;height为0&#xff0c;但是其子元素还是有高度&#xff0c;占据了空间&#xff0c;最终导致了滚动条&#xff1b; 根本原因&…

专业渗透测试 Phpsploit-Framework(PSF)框架软件小白入门教程(十三)

本系列课程&#xff0c;将重点讲解Phpsploit-Framework框架软件的基础使用&#xff01; 本文章仅提供学习&#xff0c;切勿将其用于不法手段&#xff01; 接上一篇文章内容&#xff0c;讲述如何进行Phpsploit-Framework软件的基础使用和二次开发。 我们&#xff0c;继续讲一…

Java面试题--JVM大厂篇(1-10)

引言&#xff1a; 在这个信息时代&#xff0c;对于准备进入大厂工作的朋友们来说&#xff0c;对于JVM&#xff08;Java虚拟机&#xff09;的掌握是面试中的一项重要内容。下面是一些精选的JVM面试题&#xff0c;希望对大家能有所帮助。 正文&#xff1a; 1. JVM有哪几种垃圾收…

[CISCN2024]-PWN:gostack解析(go语言程序,syscall)

查看保护 ida比较复杂&#xff0c;建议动调配合静态分析程序运行 这里函数返回不用leave和ret&#xff0c;而是利用add rsp和ret&#xff0c;所以要动调查看到底要覆盖哪里。 完整exp&#xff1a; from pwn import* pprocess(./gostack) syscall0x4616c9 pop_rax0x40f984 po…

GB报文中的Cseq值的注意点

一、 问题现象 【问题现象】NVR使用GB接三方平台发现倍速回放时&#xff0c; 【现场拓扑】现场拓扑如下 &#xff08;1&#xff09; NVR侧使用家用宽带的方式&#xff0c;通过国标跨公网接入三方平台。 图1.1&#xff1a;网络拓扑 二、 抓包分析 INVITE sip:420000004013200…

OpenAI安全系统负责人:从头构建视频生成扩散模型

作者 | Lilian Weng OneFlow编译 翻译&#xff5c;杨婷、宛子琳、张雪聃 题图由SiliconFlow MaaS平台生成 过去几年&#xff0c;扩散模型&#xff08;Diffusion models&#xff09;在图像合成领域取得了显著成效。目前&#xff0c;研究界已开始尝试更具挑战性的任务——将该技术…

深度学习Day-18:ResNet50V2算法实战与解析

&#x1f368; 本文为&#xff1a;[&#x1f517;365天深度学习训练营] 中的学习记录博客 &#x1f356; 原作者&#xff1a;[K同学啊 | 接辅导、项目定制] 要求&#xff1a; 根据本文Tensorflow代码&#xff0c;编写对应的Pytorch代码了解ResNetV2与ResNetV的区别 一、 基础…

【实战JVM】-基础篇-03-Java内存结构

【实战JVM】-基础篇-03-Java内存结构 1 运行时数据区1.1 总览1.2 程序计数器1.2.1 是否会内存溢出 1.3 java虚拟机栈1.3.1 栈帧的组成1.3.1.1 局部变量表1.3.1.2 操作数栈1.3.1.3 帧数据1.3.1.3.1 动态链接1.3.1.3.2 方法出口1.3.1.3.3 异常表 1.3.2 是否会内存溢出1.3.3 设置虚…

【神经网络结构可视化】使用 Visualkeras 可视化 Keras / TensorFlow 神经网络结构

文章目录 Visualkeras介绍下载安装代码示例1、导入必要的库2、创建VGG16神经网络模型3、可视化神经网络结构4、完整代码5、使用教程 可视化自己创建的神经网络结构1、导入要的库2、创建自己的神经网络模型3、可视化神经网络结构图4、完整代码 Visualkeras介绍 Visualkeras是一…

C++代码错误解决1(函数模板)

1、代码如下 //示例函数模板的使用 #include <iostream> #include <string> using namespace std; template <typename T>//函数模板 T max(T a,T b) {return a>b?a:b; } int main() {int a,b;cout<<"input two integers to a&b:"…

【微机原理及接口技术】可编程并行接口芯片8255A

【微机原理及接口技术】可编程并行接口芯片8255A 文章目录 【微机原理及接口技术】可编程并行接口芯片8255A前言一、8255A的内部结构和引脚1.与外设接口&#xff08;数据端口&#xff09;2.与处理器接口 二、8255A的工作方式三、8255A的编程1. 写入方式控制字&#xff1a;控制字…

从0开始回顾ElasticSearch

1 elasticsearch概述 1.1 elasticsearch简介 官网: https://www.elastic.co/ ElasticSearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎&#xff0c;基于RESTful web接口。Elasticsearch是用Java开发的&#xff0c;并作为Apache许可条款下的…

【动手学强化学习】第 6 章 Dyna-Q 算法知识点总结

【动手学强化学习】第 6 章 Dyna-Q 算法知识点总结 本章知识点基于模型的强化学习与无模型的强化学习方法简介无模型的强化学习方法基于模型的强化学习方法 强化学习算法的评价指标Dyna-Q算法Dyna-Q 算法的具体流程Dyna-Q 代码实践 本章知识点 基于模型的强化学习与无模型的强…

C++语言·list链表

其实现在在讲这些容器的时候&#xff0c;我们的重点已经不是它的接口都有什么&#xff0c;功能都是什么了&#xff0c;这些内容官网上都能查到&#xff0c;而且容器和容器之间接口的不同处很少&#xff0c;我在讲解的话也只是把官网上的东西截图下来复述一下。现在的重点其实都…

AtCoder Regular Contest 178 A~D

A.Good Permutation 2&#xff08;贪心&#xff09; 题意&#xff1a; 给你一个正整数 N N N和一个由 M M M个正整数 A ( A 1 , A 2 , … , A M ) A(A_{1},A_{2}, \dots,A_{M}) A(A1​,A2​,…,AM​)组成的序列。 在这里&#xff0c; A A A的所有元素都是介于 1 1 1和 N N …

网络编程-TCP

一、TCP的相关IP 1.1 SeverSocket 这是Socket类,对应到网卡,但是这个类只能给服务器使用. 1.2 Socket 对应到网卡,既可以给服务器使用,又可以给客户端使用. TCP是面向字节流的,传输的基本单位是字节. TCP是有连接的,和打电话一样,需要客户端拨号,服务器来听. 服务器的内核…

Stream流的使用

目录 一&#xff0c;Stream流 1.1 概述 1.2 Stream代码示例 二&#xff0c;Stream流的使用 2.1 数据准备 2.2 创建流对象 2.3 中间操作 filter map distinct sorted limit skip flatMap 2.4 终结操作 foreach count max&min collect 2.5 查找与匹配 a…

redis中String,Hash类型用法与场景使用

String 用法 1. 设置键值对 &#xff08;1&#xff09;设置键值对使用 set 命令设置 key 的值。 返回值&#xff1a;ok&#xff0c;如果 key 已经存在&#xff0c;set 命令会覆盖旧值。 &#xff08;2&#xff09;使用 setex 命令设置 key 的值并为其设置过期时间&#xff…