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


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

目录


🦅数据库基础

🐀什么是数据库

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

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

🐏主流数据库

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

🦆MySQL数据库的基本使用

连接服务器
  • 输入:
bash 复制代码
mysql -h 127.0.0.1 -P 3306 -u root -p
  • 输出:
bash 复制代码
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相关知识理解与铺垫

mysql与mysqld的区分
  • 我们平时所说的mysql是数据库的客户端

  • mysqld是数据服务的服务端

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

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

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

  • 数据库服务是指的:mysqld

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

🐟服务器管理

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

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

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

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

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

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

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

bash 复制代码
 vim /etc/mysql/mysql.conf.d/mysqld.cnf   #打开MySQL配置文件
  • 如下图就是默认的数据存储路径:
测试证明上面所述结论
  • 创建了一个名字叫database1的数据库
  • 并且在创建的库中创建了一张表
bash 复制代码
create database database1;  #创建数据库

use database1;  #使用数据库/进入数据库

create table student(   # 建立一张表
id int,
name varchar(32),
gender varchar(2)
);
实验结果
  • 进入该数据库(本质就是一个目录),可以发现我们所建立的一张student表:

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

🐕数据库简单使用示例

  • 创建数据库
bash 复制代码
create database database1;
  • 使用数据库
bash 复制代码
use database1;
  • 创建数据库表
bash 复制代码
create table student(
id int,
name varchar(32),
gender varchar(2)
);
  • 表中插入数据
bash 复制代码
insert into student (id, name, gender) values (1, '张三', '男');
insert into student (id, name, gender) values (2, '李四', '女');
insert into student (id, name, gender) values (3, '王五', '男');
  • 查询表中的数据
bash 复制代码
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的核心就是插件式存储引擎,支持多种存储引擎。

查看存储引擎

bash 复制代码
show engines;

相关推荐
苹果醋315 分钟前
golang 编程规范 - Effective Go 中文
java·运维·spring boot·mysql·nginx
步、步、为营43 分钟前
.net无运行时发布原理
linux·服务器·.net
暮湫1 小时前
MySQL(1)概述
数据库·mysql
fajianchen1 小时前
记一次线上SQL死锁事故:如何避免死锁?
数据库·sql
chengpei1471 小时前
实现一个自己的spring-boot-starter,基于SQL生成HTTP接口
java·数据库·spring boot·sql·http
等一场春雨1 小时前
CentOS 安装Redis
linux·redis·centos
心灵Haven1 小时前
CentOS 7乱码问题如何解决?
linux·运维·centos
__pop_1 小时前
记录一次 centos 启动失败
linux·运维·服务器·centos
狂爱代码的码农1 小时前
在centos上编译安装opensips【初级-默认安装】
linux·运维·centos
叫我:松哥1 小时前
基于Python django的音乐用户偏好分析及可视化系统设计与实现
人工智能·后端·python·mysql·数据分析·django