【MySQL】MySQL数据库入门:构建你的数据基石

devtools/2024/11/18 21:10:49/
🍑个人主页:Jupiter.
🚀 所属专栏:MySQL初阶探索:构建数据库基础
欢迎大家点赞收藏评论😊

在这里插入图片描述

在这里插入图片描述

目录

  • `🦅数据库基础`
    • `🐀什么是数据库`
    • `🐏主流数据库`
      • `🦆MySQL数据库的基本使用`
        • `连接服务器`
      • `🐓MySQL相关知识理解与铺垫`
      • `🐟服务器管理`
      • `🐱服务器,数据库,表关系`
        • `测试证明上面所述结论`
        • `实验结果`
      • `🐕数据库简单使用示例`
      • `🐍数据逻辑存储`
      • `🐉MySQL架构`
      • `🐒SQL分类`
      • `🐂存储引擎`


🦅数据库基础

🐀什么是数据库

存储数据用文件就可以了,为什么还要弄个数据库?

  • 文件保存数据有以下几个缺点
    • 文件的安全性问题
    • 文件不利于数据查询和管理
    • 文件不利于存储海量数据
    • 文件在程序中控制不方便
  • 数据库存储介质:
    • 磁盘
    • 内存
      为了解决上述问题,专家们设计出更加利于管理数据的东西——数据库,它能更有效的管理数据。数据库的水平是衡量一个程序员水平的重要指标。

🐏主流数据库

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

🦆MySQL数据库的基本使用

连接服务器
  • 输入:
mysql -h 127.0.0.1 -P 3306 -u root -p
  • 输出:
root@iZ2vcb2izu72dt7ghpv46fZ:~# mysql -h 127.0.0.1 -P 3306 -u root -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 13
Server version: 8.0.39-0ubuntu0.22.04.1 (Ubuntu)Copyright (c) 2000, 2024, Oracle and/or its affiliates.Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.mysql> 

注意

  • 如果没有写 -h 127.0.0.1 ,默认是连接本地;
  • 如果没有写 -P 3306 ,默认是连接3306端口号;

🐓MySQL相关知识理解与铺垫

mysqlmysqld_73">mysqlmysqld的区分
  • 我们平时所说的mysql数据库客户端

  • mysqld是数据服务的服务端

  • mysql的本质:是基于C(mysql)S(mysqld)模式的一种网络结构;

  • mysql是一套给我们提供数据存储服务的网络程序

  • 数据库一般是指:在磁盘或内存中存储的特定结果组织的数据—将来在磁盘存储的一套数据方案

  • 数据库服务是指的:mysqld

再次解释为什么要有数据库
  • 文件提供的数据储存功能,但是没有提供很号的数据内容做管理的能力(比如在一个文件中查找所有id为1000的电话号码,如果没有数据库的存在,程序员只能使用编程自己实现,比较麻烦)。
  • 数据库的本质:是对数据内容存储的一套解决方案,只需要给相应的字段,数据库直接给出相应的结果。
    在这里插入图片描述

🐟服务器管理

执行 win+r 输入 services.msc 打开服务管理器,通过下图左侧停止,暂停,重启动按钮进行服务管理
在这里插入图片描述

🐱服务器,数据库,表关系

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

注意:所谓的建立一个数据库,实质上就是在一个特定的目录下建立一个目录,在一个数据库中建立一张,实质上就是在该目录中建立一个文件

怎么理解这个特定的目录?

  • 这个特定的目录一般是在MySQL的配置文件中所设置的数据默认存储路径:

  • 查看数据存储默认路径:

 vim /etc/mysql/mysql.conf.d/mysqld.cnf   #打开MySQL配置文件
  • 如下图就是默认的数据存储路径:

在这里插入图片描述

测试证明上面所述结论
  • 创建了一个名字叫database1的数据库
  • 并且在创建的库中创建了一张表
create database database1;  #创建数据库use database1;  #使用数据库/进入数据库create table student(   # 建立一张表
id int,
name varchar(32),
gender varchar(2)
);
实验结果

在这里插入图片描述

  • 进入该数据库(本质就是一个目录),可以发现我们所建立的一张student表:
    在这里插入图片描述

数据库服务器、数据库和表的关系如下:
在这里插入图片描述

🐕数据库简单使用示例

create database database1;

在这里插入图片描述

use database1;
create table student(
id int,
name varchar(32),
gender varchar(2)
);
  • 表中插入数据
insert into student (id, name, gender) values (1, '张三', '男');
insert into student (id, name, gender) values (2, '李四', '女');
insert into student (id, name, gender) values (3, '王五', '男');
  • 查询表中的数据
select * from student;

在这里插入图片描述

🐍数据逻辑存储

  • 表是一个二维的,具有行与列,这只是逻辑上的存储结构,实际中MySQL中表数据的存储不提顶是这样存储的;

在这里插入图片描述

🐉MySQL架构

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

在这里插入图片描述

🐒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

🐂存储引擎

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

查看存储引擎

show engines;

在这里插入图片描述



http://www.ppmy.cn/devtools/135031.html

相关文章

【计算机网络】HTTP协议

一、网址 1.URL URL就是我们平时说的网址 2.urlencode/urldecode 像 / ? : 等这样的字符,已经被url当做特殊意义理解了。因此这些字符不能随意出现 如果某个参数中需要带有这些特殊字符,就必须先对特殊字符进行转义 -> urlencode 服务器收到url…

《FreeRTOS列表和列表项篇》

FreeRTOS列表和列表项 1. 什么是列表和列表项?1.1 列表list1.2 列表项list item 2. 列表和列表项的初始化2.1 列表的初始化2.2 列表项的初始化 3. 列表项的插入4. 列表项末尾插入5. 列表项的删除6. 列表的遍历 列表和列表项是FreeRTOS的一个数据结构,是F…

为了数清还有几天到周末,我用python绘制了日历

日历的秘密 昨天,在看小侄子写作业的时候,发现了一个秘密:他在“演算纸”(计算数学题用的草纸)上画了非常多的日历。对此我感到了非常的困惑,“这是做什么的?” 后来,经过了我不懈…

如何使用正则表达式验证域名

下面是一篇关于如何使用正则表达式验证域名的教程。 如何使用正则表达式验证域名 简介 域名是互联网上网站的地址,每个域名由多个标签(label)组成,标签之间用点 . 分隔。域名规则有很多细节,但基本要求是&#xff1a…

【java】java通过s3访问ceph报错

1.报错信息、背景 工作中起了几个访问ceph的服务pod节点,一段时间后1个节点一直报错Unable to execute HTTP request: Timeout waiting for connection from pool,详细i信息如下图片,有且仅有1个节点报错,其他节点访问正常。看日志…

数据结构与算法分析模拟试题及答案5

模拟试题(五) 一、单项选择题(每小题 2 分,共20分) (1)队列的特点是(   )。 A)先进后出 B)先进先出 C)任意位置进出 D&#xff0…

机器学习1

学习分类:监督学习、半监督学习、无监督学习、强化学习 监督学习:从有标签的训练数据中学习模型,然后对某个给定的新数据利用模型预测它的标签。 半监督学习:利用少量标注数据和大量无标注数据进行学习的模式 无监督学习&#…

unity小:shaderGraph不规则涟漪、波纹效果

实现概述 在本项目中,我们通过结合 Sine、Polar Coordinates 和 Time 节点,实现了动态波纹效果。以下是实现细节: 核心实现 Sine 波形生成: 使用 Sine 节点生成基本的波形。该节点能够创建周期性变化,为波纹效果提供…