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

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

在这里插入图片描述

在这里插入图片描述

目录

  • `🦅数据库基础`
    • `🐀什么是数据库`
    • `🐏主流数据库`
      • `🦆MySQL数据库的基本使用`
        • `连接服务器`
      • `🐓MySQL相关知识理解与铺垫`
        • `mysql与mysqld的区分`
        • `再次解释为什么要有数据库`
      • `🐟服务器管理`
      • `🐱服务器,数据库,表关系`
        • `测试证明上面所述结论`
        • `实验结果`
      • `🐕数据库简单使用示例`
      • `🐍数据逻辑存储`
      • `🐉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相关知识理解与铺垫

mysql与mysqld的区分
  • 我们平时所说的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.mzph.cn/pingmian/60983.shtml

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

相关文章

linux企业中常用NFS、ftp服务

1.静态ip配置 修改ip地址为静态vim /etc/sysconfig/network-scripts/ifcfg-enxxx BOOTPROTO"static" IPADDR192.168.73.10 GATEWAY192.168.73.2 # 该配置与虚拟机网关一致 NETMASK255.255.255.0重启网卡:systemctl restart network.service ping不通域名…

6.584-Lab1:MapReduce

前置知识/概念 Raft 是一个基于“Leader”的协议,能够保证分布式网路的一致性。 RPC(Remote Producer Call) 参考链接1 参考链接2 Go中RPC的简单实现 Golang中regexp正则表达式的用法 https://gukaifeng.cn/posts/golang-zheng-ze-biao-…

抽象java入门1.5.3.1——类的进阶

前言:在研究神技代码Hello word的时候,发现了一个重大公式bug,在代码溯源中,我发现了一个奇怪的东西,就是OUT不是类中类(不是常规类的写法) 内容总结: 代码运行的顺序复习 正片开始…

人力资源招聘系统的革新之路:从传统到智能的转变

在全球化与数字化交织的今天,企业间的竞争日益激烈,而人才作为企业发展的核心驱动力,其重要性不言而喻。传统的人力资源招聘方式,如依赖纸质简历、人工筛选、面对面面试等,不仅效率低下,且难以精准匹配企业…

Bootstrap和jQuery开发案例

目录 1. Bootstrap和jQuery简介及优势2. Bootstrap布局与组件示例:创建一个响应式的表单界面 3. jQuery核心操作与事件处理示例:使用jQuery为表单添加交互 4. Python后端实现及案例代码案例 1:用户登录系统Flask后端代码前端代码 5. 设计模式…

使用python-Spark使用的场景案例具体代码分析

使用场景 1. 数据批处理 • 日志分析:互联网公司每天会产生海量的服务器日志,如访问日志、应用程序日志等。Spark可以高效地读取这些日志文件,对数据进行清洗(例如去除无效记录、解析日志格式)、转换(例如…

AXI DMA IP BUG踩坑记录

1. 问题描述 在突发的过程中总是一旦使用XAxiDma_SimpleTransfer函数就会出现AXI STREAM信号的READY信号先拉高4个数据(32位)的时钟后会迅速拉低,换句话说就是一旦PS端发起了XAxiDma_SimpleTransfer,AXI总线的READY信号就会拉高四个节拍,这样就会导致传输的数据出现问题。…

Vue2教程001:初识Vue

文章目录 1、初识Vue1.1、Vue2前言1.2、创建Vue实例1.3、插值表达式1.4 Vue响应式特性 1、初识Vue 1.1、Vue2前言 Vue是什么? 概念:Vue是一个用于构建用户界面的渐进式框架。 Vue的两种使用方式: Vue核心包开发 场景:局部模块…

【jvm】HotSpot中方法区的演进

目录 1. 说明2. JDK1.6及以前3. JDK1.74. JDK1.8及以后 1. 说明 1.在HotSpot虚拟机中,方法区(Method Area)的演进是一个重要的内存管理优化过程。2.从JDK1.6到JDK1.8,HotSpot虚拟机中的方法区经历了从永久代到元空间的重大变化。…

API 数据处理与 SQL 批量更新技巧:CASE 语句优化操作指南

前言 在现代应用程序开发中,数据处理和数据库操作是不可或缺的一部分。特别是在处理大量数据时,如何高效地更新数据库记录成为了关键问题。本文将对比两种常见的数据库更新方法:一种是使用 CASE 语句进行批量更新,另一种是通过循…

高级java每日一道面试题-2024年11月10日-框架篇[SpringBoot篇]-你对SpringBoot了解多少?

如果有遗漏,评论区告诉我进行补充 面试官: 你对SpringBoot了解多少? 我回答: 在Java高级面试中,SpringBoot是一个经常被提及的话题。以下是对SpringBoot的详细解析: SpringBoot概述 SpringBoot是Spring开源组织下的子项目,是Spring组件…

Linux dpkg命令详解

一、简介 dpkg 是基于 Debian 发行版 Linux 系统的低级包管理工具&#xff0c;可以手动安装、配置、移除 .deb 包&#xff0c;与 apt 命令不同的是&#xff0c;dpkg 不会自动处理包之间的依赖关系。 二、常用选项 安装包 sudo dpkg -i <package_name>.deb手动处理包依…

vscode vite+vue3项目启动调试

1、经常我们在普通的项目中&#xff0c;如果算法并不复杂&#xff0c;那么基本上console.log就可以搞定&#xff0c;当然也可以直接alert&#xff0c;打包的时候如果不去掉&#xff0c;还会在发版中上接弹出&#xff0c;给你个惊喜。 2、碰到了有些算法过程比较复杂的情况下&a…

如何给openshift 单节点集群配置hugepage

目前我有一台arm服务器, 是配置的单节点集群, 这个节点为是master, 也是worker. 理论上我应该用worker 标签给node 配置hugepage. 所以使用了以下方法: cat << EOF > hugepageconfig.yaml apiVersion: machineconfiguration.openshift.io/v1 kind: MachineCo…

Jdbc学习笔记(三)--PreparedStatement对象、sql攻击(安全问题)

目录 &#xff08;一&#xff09;使用PreparedStatement对象的原因&#xff1a; 使用Statement对象编写sql语句会遇到的问题 ​编辑 &#xff08;二&#xff09;sql攻击 1.什么是sql攻击 2.演示sql攻击 &#xff08;三&#xff09;防止SQL攻击 1.PreparedStatement是什么 …

java导出pdf

引入包 <properties><itext.version>8.0.5</itext.version></properties><dependencies><dependency><groupId>com.itextpdf</groupId><artifactId>itext-core</artifactId><version>${itext.version}</…

C/C++基础知识复习(23)

) 什么是 C 内联函数&#xff1f;它的作用是什么&#xff1f; C 内联函数&#xff08;inline function&#xff09; 是一种通过编译器优化的特殊函数。内联函数的主要作用是减少函数调用的开销&#xff0c;使得程序执行更加高效&#xff0c;尤其是对于那些频繁调用的函数。 当…

表单自动化填写-JavaScript脚本

一、场景 在日常工作、生活中常常会遇到需要填写、提交web表单的场景&#xff0c;往往涉及到了大量机械、重复的工作。作为程序员&#xff0c;我们崇尚消除重复、实现流程自动化、合理偷懒。 通过浏览器的控制台运行JavaScript脚本&#xff0c;可以简单的实现对web表单的填写…

后端分层解耦

引入 在上篇所举的例子中&#xff0c;我们将所有的代码均放在HelloControl方法之中&#xff0c;这样会导致代码的复用性、可读性较差&#xff0c;难以维护。因此我们需 三层架构 在之前的代码中&#xff0c;代码大体可以分为三部分&#xff1a;数据访问、数据逻辑处理、响应数…

97.【C语言】数据结构之栈

目录 栈 1.基本概念 2.提炼要点 3.概念选择题 4.栈的实现 栈初始化函数 入栈函数 出栈函数和栈顶函数 栈顶函数 栈销毁函数 栈 基本概念参见王爽老师的《汇编语言 第四版》第56和57页 节选一部分 1.基本概念 注意:这里提到的数据结构中的栈有别于操作系统的栈,后者是…