【MySQL】数据库基础知识

欢迎拜访:雾里看山-CSDN博客
本篇主题:【MySQL】数据库基础知识
发布时间:2025.1.21
隶属专栏:MySQL

在这里插入图片描述

目录

  • 什么是数据库
    • 为什么要有数据库
    • 数据库的概念
  • 主流数据库
  • mysql的安装
  • mysql登录
  • 使用一下mysql
    • 显示数据库内容
    • 创建一个数据库
    • 创建一张表
    • 插入数据
    • 查询数据
    • 清屏命令
    • 总结
  • 服务器,数据库,表关系
  • 数据逻辑存储
  • mysql架构
  • mysql的分类
  • 存储引擎
    • 什么是存储引擎
    • 查看存储引擎
    • 存储引擎对比

什么是数据库

为什么要有数据库

我们知道文件可以保存数据,那么为什么还需要数据库呢?

文件存储数据的缺点

  1. 数据冗余度高。当在多个文件中存储相似的数据时,可能会出现相同的数据重复存储的情况。例如,在一个学校的文件系统中,学生的基本信息(如姓名、性别、出生日期等)可能会在成绩文件、考勤文件等多个文件中重复出现。这不仅浪费存储空间,而且当需要更新学生基本信息时,需要在多个文件中分别修改,容易导致数据不一致。
  2. 数据一致性差。由于数据分散在多个文件中,很难保证数据的一致性。如果在一个文件中修改了数据,而忘记在其他相关文件中进行同步修改,就会导致数据冲突。比如,在商品库存管理中,进货文件更新了商品的库存数量,但销售文件没有及时更新,就会使库存数据出现错误。
  3. 数据关联性弱。文件系统一般是按照文件的格式和用途来组织的,很难有效地表示数据之间的复杂关系。例如,在一个企业的客户订单管理系统中,一个客户可能有多个订单,每个订单又包含多种商品。在文件系统中很难直观地体现客户 - 订单 - 商品之间的这种多层次的关联关系,查询和管理这些关联数据会变得非常复杂。
  4. 数据安全性低。文件系统通常提供的安全机制比较有限。例如,在操作系统层面,对文件的访问控制主要基于用户权限,对于文件内部的数据安全保护措施相对薄弱。对于一些敏感数据,如银行账户信息、企业商业机密等,文件系统很难提供足够细粒度的安全访问控制,容易导致数据泄露。
  5. 数据检索效率低。在文件系统中进行数据检索,特别是对复杂条件的检索,效率往往比较低。例如,要在一个包含大量文本文件的文件夹中查找满足特定关键词组合的文件,需要遍历每个文件的内容,这会花费大量的时间。而且如果文件没有良好的组织结构和索引机制,随着文件数量的增加,检索速度会急剧下降。

为了解决上述问题,专家们设计出更加利于管理数据的东西——数据库,它能更有效的管理数据。

数据库的概念

一般文件确实提供了数据的存储功能,但是文件并没有很好的提供内容数据的管理能力(用户角度)。
数据库(Database,简称DB)是按照数据结构来组织、存储和管理数据的仓库。它是一个长期存储在计算机内的、有组织的、可共享的、统一管理的数据集合。这些数据可以是文本、数字、图像、音频、视频等多种类型,并且是为了满足各种应用程序和用户的需求而存在的。
数据库的本质:对数据内容存储的一套解决方案,用户给数据库字段或者要求,数据库直接返回用户结果,不在需要用户对文件内容进行分析。
数据库一般指的是,在在磁盘或者内存中存储的特定结构组织的数据 — 将来在磁盘上存储的一套数据库方案。
数据库服务 一般指的是 数据库的服务端 mysqld
mysql : 是一套给我提供数据存取服务的网络程序。
站在系统层面:

  • 是否启动mysql
    在这里插入图片描述
  • 区分mysql和mysqld
    在这里插入图片描述
    mysq是数据库服务的客户端
    mysqld是数据库服务的服务器端
    mysql本质是基于CS模式的一种网络服务

主流数据库

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

mysql的安装

  • Centos 6.5下编译安装MySQL 5.6.14
  • CentOS 7 通过 yum 安装 MariaDB
  • Windows下安装MySQL5.7

mysql登录

在Linux系统下的登录命令:

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

在这里插入图片描述
如果没有写 -h 127.0.0.1 默认是连接本地。
如果没有写 -P 3306 默认是连接3306端口号。

使用一下mysql

样例:
使用mysql建立一个数据库,建立一张表结构,插入一些数据 — 对比一下mysql在Linux中是如何表现的。

显示数据库内容

mysql命令:

show databases;

在这里插入图片描述
mysql的所有内容都存储在 /var/lib/mysql的文件夹里面
在这里插入图片描述

创建一个数据库

create database helloworld

在这里插入图片描述
创建数据库,本质就是在Linux的一个目录
在这里插入图片描述

创建一张表

use helloworld;    //进入相应的数据库create table student(
name varchar(32),
age int,
gender varchar(2)                                                     
);

在这里插入图片描述
在数据库内建立表,本质就是在Linux下创建文件
在这里插入图片描述

插入数据

insert into student (name, age, gender) values ('张三', 20, '男');

在这里插入图片描述

查询数据

select * from student;

在这里插入图片描述

清屏命令

system clear;

总结

  1. 创建数据库,本质就是在Linux的一个目录。
  2. 在数据库内建立表,本质就是在Linux下创建文件。
  3. 数据库的本质也是文件!!!只不过这些文件并不由程序员自己操作,而是由数据库服务帮我们操作。

服务器,数据库,表关系

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

数据逻辑存储

数据库是一种行列式结构
在这里插入图片描述

mysql架构

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

mysql的分类

  • 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;

在这里插入图片描述
最常用的是InnoDBMYISAM

存储引擎对比

在这里插入图片描述

⚠️ 写在最后:以上内容是我在学习以后得一些总结和概括,如有错误或者需要补充的地方欢迎各位大佬评论或者私信我交流!!!

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

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

相关文章

优化使用 Flask 构建视频转 GIF 工具

优化使用 Flask 构建视频转 GIF 工具 优化后的项目概述 在优化后的版本中,我们将实现以下功能: 可设置每个 GIF 的帧率和大小:用户可以选择 GIF 的帧率和输出大小。改进的用户界面:使用更现代的设计使界面更美观、整洁。自定义…

R 语言 | future 包,非阻塞的执行耗时脚本

目的:有一段代码,后面暂时用不到,但是又很耗时,占了当前R session,难道只能等半个小时,等到它结束才能画图? 可以使用R多线程,在支线中执行耗时任务,同时不阻塞当前R进程…

使用插件SlideVerify实现滑块验证

作者gitee地址:https://gitee.com/monoplasty/vue-monoplasty-slide-verify 使用步骤: 1、安装插件 npm install --save vue-monoplasty-slide-verify 2、在main.js中进行配置 import SlideVerify from vue-monoplasty-slide-verify; Vue.use(SlideV…

Windows配置frp内网穿透实现远程连接

仅个人记录 本文仅介绍客户端的配置 1. 开始 frp分为服务端和客户端,为实现内网穿透需要同时配置服务端和客户端,并且版本保持一致,可以前往 frp github下载 本文使用 0.51.2 版本,从GitHub下载并解压,得到如下文件…

“大模型横扫千军”背后的大数据挖掘--浅谈MapReduce

文章目录 O 背景知识1 数据挖掘2 邦费罗尼原则3 TF.IDF4 哈希函数5 分布式文件系统 一、MapReduce基本介绍1. Map 任务2. 按键分组3. Reduce 任务4. 节点失效处理5.小测验:在一个大型语料库上有100个map任务和若干reduce任务: 二、基于MapReduce的基本运…

第17个项目:Python烟花秀

源码下载地址:https://download.csdn.net/download/mosquito_lover1/90295693 核心源码: import pygame import random import math from PIL import Image import io # 初始化pygame pygame.init() # 设置窗口 WIDTH = 800 HEIGHT = 600 screen = pygame.display.s…

GDB相比IDE有什么优点

GDB(GNU Debugger)相比于集成开发环境(IDE)具有一些独特的优点,主要体现在其灵活性、可定制性和低级控制能力。具体来说,GDB有以下几个优点: 1. 轻量级且无依赖 GDB是一个命令行工具,不依赖于任何复杂的图形界面或大型库,这使得它非常适合在资源受限的环境中使用,比…

JavaScript学习笔记(1)

html 完成了架子, css 做了美化,但是网页是死的,我们需要给他注入灵魂,所以接下来我们需要学习 JavaScript,这门语言会让我们的页面能够和用户进行交互。 一、引入方式 1.内部脚本 将 JS 代码定义在 HTML 页面中 Jav…

如何判断以太坊地址类型?

如何判断以太坊地址类型? 一、账户类型解释 2.1 以太坊外部账户(Externally Owned Account,EOA) 外部账户(EOA)是由私钥控制的账户,在以太坊网络中用来发送交易和执行其他操作。EOA 不是智能…

大华前端开发面试题及参考答案 (下)

opacity、display 和 visibility 的区别是什么? 含义与作用 opacity:用于设置元素的透明度,取值范围从 0 到 1,0 表示完全透明(不可见),1 表示完全不透明。它会使元素及其内容包括子元素都按照指定的透明度进行显示,改变的是视觉上的透明程度。display:用于规定元素应…

二十七、资源限制-LimitRange

LimitRange生产必备 在调度的时候 requests 比较重要,在运行时 limits 比较重要。 一、产生原因 生产中只有ResourceQuota是不够的 只配置ResourceQuotas的情况下,pod的yaml文件没有配置resources配置,都是0的话,就可以无限配置,永远达不到limit LimitRange做了什么 如…

docker部署的gitlab迁移

docker部署的gitlab迁移_docker gitlab 迁移-CSDN博客 gitlab-rake gitlab:backup:restore BACKUP 后面一路yes 生活中总是充满了各种选择,点餐纠结,出行选择,聚餐座位,团队投票结果不明,随机抽签一锤定音等等&#xf…

【Pytest】基础到高级功能的理解使用

文章目录 第一部分:Pytest 简介1.1 什么是 Pytest?1.2 Pytest 的历史1.3 Pytest 的核心概念1.4 Pytest 的特点1.5 为什么选择 Pytest? 第二部分:Pytest 的基本使用2.1 安装 Pytest2.2 编写第一个测试用例2.2.1 创建一个简单的测试…

GS论文阅读--GeoTexDensifier

前言 本文是一个关于高斯致密化策略对高斯地图进行优化,他主要关注了几何结构和纹理信息。我最近对于高斯点的分布比较感兴趣,因为高斯点的分布决定了之后重建质量的好坏,初始化高斯很重要,但之后的维护需要致密化与修建策略&…

支持大功率输出高速频闪的图像处理用光源控制器

机器视觉系统中的光源控制器在确保图像质量、提高系统稳定性、降低能耗以及方便系统扩展和升级等方面发挥着重要作用。它可提供稳定光源,调节参数,另外具有操作便捷性。 下面我们来看Gardasoft的光源控制器,Gardasoft拥有作为图像处理用LED光…

关于opensips的帮助命令的解释

opensips -help以下是 opensips 命令及其选项的中文解释(基于 3.6.0-dev 版本): 命令用法 bash复制代码opensips -l 地址 [-l 地址 ...] [选项]选项说明 选项功能-f 文件指定配置文件(默认为 /usr/local//etc/opensips/opensips…

centos下设置服务器开机自启动 redis

在客户服务器中,服务器重启,发现 Redis 没有重启, 可以按照类似的步骤来创建自启动脚本,并将它添加到定时任务中。 解决办法: 1. 创建自启动脚本 进入服务器并创建脚本文件,例如 /usr/local/bin/redis_…

链表相交1

给你两个单链表的头节点 headA 和 headB ,请你找出并返回两个单链表相交的起始节点。如果两个链表没有交点,返回 null 。 思路 这一题我不认为很难,去吸收知识就行了,不要总是想着独创。 简单来说,就是求两个链表交点…

Excel 技巧17 - 如何计算倒计时,以及数据条(★)

本文讲如何计算倒计时,以及加数据条。 1,如何计算倒计时 这里也要用公式 D3 - TODAY() 显示为下面这个样子的 然后右键该单元格,选 设置单元格格式 然后点 常规 这样就能显示出还书倒计时的日数了。 下拉适用到其他单元格。 2,…

springboot整合modbus实现通讯

springboot整合modbus4j实现tcp通讯 前言 本文基于springboot和modbus4j进行简单封装,达到开箱即用的目的,目前本方案仅实现了tcp通讯。代码会放在最后,按照使用方法操作后就可以直接使用 介绍 在使用本方案之前,有必要对modb…