【MySQL】数据库基础知识

本文基于Linux的MySQL

文章目录

  • 一. 什么是数据库
  • 二. 主流数据库
  • 三. 服务器,数据库和表的关系
  • 四. MySQL架构
  • 五. SQL语句分类
  • 结束语

一. 什么是数据库

数据库本质是对数据内容存储的一套解决方案
如何理解呢?
首先,说到数据内容存储,文件是更为大众所知的数据存储形式。那为什么还会出现数据库呢?
比如这样一个场景,一个文件中,有十万个人的信息,如果要求找出这之中,身份证尾号为1102的,如何操作呢?很多人想,这不就是文件操作,从文件读数据,然后进行筛选。这样的确可以,但这一过程需要认为操作,那我们是否可以将这一过程交给别人完成呢?数据库的功能就是如此。
文件保存数据有以下几个缺点:

  • 文件的安全性问题
  • 文件不利于存储海量数据
  • 文件只有读写功能
  • 文件在程序中控制不方便

数据库就是基于文件系统,提供更好的数据管理能力
实现用户给予字段或者需求,数据库可以对数据进行筛选,并提交结果

PS:数据库是基于文件系统的,所以其存储介质仍是磁盘内存

二. 主流数据库

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

三. 服务器,数据库和表的关系

首先,在MySQL的配置文件/etc/my.cnf中,我们可以查看数据的默认存储路径

在这里插入图片描述
默认存放在/var/lib/mysql


当前的/var/lib/mysql中是这样的

在这里插入图片描述

简单建立一个helloMySQL的数据库,在helloMySQL中创建表,并插入一些数据

create database helloMySQL; 创建数据库
use helloMySQL; 使用数据库
create table student(...);创建数据库表
insert into student (...) values(...) 表中插入数据
select * from student 查询表中数据

在创建数据库后,/var/lib/mysql是这样的

在这里插入图片描述

可以看到,多了一个helloMySQL的目录

紧接着,我们创建表
在这里插入图片描述

helloMySQL目录中就会多出几个文件

在这里插入图片描述

尝试插入数据

在这里插入图片描述

我们简单使用了一下数据库。
其实建数据库在Linux层面就是创建了一个目录建表就是创建文件

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

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

在这里插入图片描述

四. MySQL架构

在这里插入图片描述

在这里插入图片描述

MySQL的架构可以大致分为三层

  • 第一层:连接器。用于管理连接,权限验证
  • 第二层:分析器,优化器,执行器。用于SQL语句的解析,传递
  • 第三层:存储引擎:插件式存储引擎,数据库管理系统如何存储数据,如何为存储的数据建立索引和如何更新,查询数据等技术的实现方式。

show engines 查看存储引擎
常用的有innoDBMyISAM

五. 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.rhkb.cn/news/126718.html

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

相关文章

解决防火墙导致虚拟机不能ping通宿主机的问题

今天,无缘无故的,虚拟机突然用不了,网络连上不了,一番折腾翻找,最后才发现,是因为虚拟机ping不同宿主主机了,连网关都ping不通了,但是,宿主主机却可以ping通虚拟机 。 最…

element-ui dialog弹窗 设置点击空白处不关闭

根据官网提供方法 场景:vue实现的网站有两个弹窗同时出现时,关闭报警,批量进度条弹窗也关闭了, 1、每一个页面都有可能出现的报警弹窗, 2、页面a批量操控硬件添加操作的进度条弹窗 开始以为是因为点击报警弹窗&#…

高效数据湖构建与数据仓库融合:大规模数据架构最佳实践

文章目录 数据湖和数据仓库:两大不同理念数据湖数据仓库 数据湖与数据仓库的融合统一数据目录数据清洗和转换数据安全和权限控制数据分析和可视化 数据湖与数据仓库融合的优势未来趋势云原生数据湖自动化数据处理边缘计算与数据湖融合 结论 🎉欢迎来到云…

利用python进行视频下载并界面播放快速下载素材

工具:python designer(python自带):UI界面设计工具 VLC:视频播放工具 需要的库如下: import os,platform os.environ[PYTHON_VLC_MODULE_PATH] "./vlc-3.0.14" import vlc from 脚本 import Player from …

STM32 硬件IIC 控制OLED I2C卡死问题

#更新通知:2023-09-06 STM32L151 固件库 使用I2C 太难了,又宕机了,建议不要在固件库版本上尝试硬件IIC 了,一般人真用不了,直接使用软件模拟的,或者不要使用固件库了,用HAL 库吧,据说…

APP启动优化Android篇

背景 为什么重提启动优化?首先,用户进入APP唯一的路径就是启动,这是体验核心链路的第一环。启动分为冷启动、热启动和温启动,本文中「启动」一词如果没有特别说明,均为冷启动。启动时间过长,会造成用户流失…

C++内存泄露

目录 1.什么是内存泄露 2.内存泄露的危害 3.如何解决内存泄露等相关的问题 1.什么是内存泄露 在C/C中 ,我们申请了资源,因为一些原因忘记对申请的资源进行释放,或者因为异常安全等问题没有进行释放就会造成内存泄露的。 2.内存泄露的危害…

【好书推荐】《速学Linux:系统应用从入门到精通》

目录 前言一、为什么学习Linux系统二、Linux系统的应用领域1.Linux在服务器的应用2.嵌入式Linux的应用3.桌面Linux的应用 三、Linux的版本选择1、经验人士使用的Debian2、以桌面应用为主的Ubuntu3、以经典桌面配置为主的Mint4、社区企业操作系…

【Docker】用Dockerfile制作个人的镜像文件

作者简介: 辭七七,目前大一,正在学习C/C,Java,Python等 作者主页: 七七的个人主页 文章收录专栏: 七七的闲谈 欢迎大家点赞 👍 收藏 ⭐ 加关注哦!💖&#x1f…

《DevOps实践指南》- 读书笔记(一)

DevOps实践指南 Part 1 DevOps 介绍精益运动敏捷宣言 1. 敏捷、持续交付和三步法1.1 制造业价值流1.2 技术价值流1.2.1 聚焦于部署前置时间1.2.2 关注返工指标——%C/A 1.3 三步工作法:DevOps 的基础原则 2. 第一步:流动原则2.1 使工作可见2.2 限制制品数…

力扣|找出和所对应的两数的下标

从零开始刷力扣(bushi 题目放在这: 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出和为目标值target的两个整数,并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是,数组中同一…

提升你的Android开发技能:从AR/VR沉浸到UI设计和故障排除

文章目录 探索最新AR/VR应用在教育、游戏、医疗等领域的应用教育领域游戏领域医疗领域 深入了解Android内存管理与性能优化的方法与技巧垃圾回收机制内存泄漏使用弱引用避免过度渲染内存优化图像优化延迟加载Android中的调试技术应用程序分析 分享如何提高Android应用的易用性和…

【算法专题突破】滑动窗口 - 长度最小的子数组(9)

目录 1. 题目解析 2. 算法原理 3. 代码编写 写在最后: 1. 题目解析 题目链接:209. 长度最小的子数组 - 力扣(Leetcode) 要注意的是,题目给的是正整数, 而题目要求并不难理解,就是找最短的…

领域驱动设计:领域事件

文章目录 领域事件识别领域事件领域事件相关案例领域事件总体架构 领域事件 领域事件是领域模型中非常重要的一部分,用来表示领域中发生的事件。一个领域事件将导致进一步的业务操作,在实现业务解耦的同时,还有助于形成完整的业务闭环。 举例…

【面试专题】Spring篇②

📃个人主页:个人主页 🔥系列专栏:Java面试专题 目录 1.spring-bean的循环依赖 2.springMVC执行流程 3.Springboot自动配置原理 4.Spring框架常见的注解(Spring,SpringMVC,SpringBoot&#x…

qsort 函数的使用

一、qsort 函数的形式 1.1使用 qsort 函数包含的库 1.2qsort 函数的参数 qsort:对数组的元素进行排序 1.3参数中的 compar 函数 struct stu {char name[20];//姓名int age;//年龄double grade;//成绩 }; int cmp_name(void* p1, void* p2) {//如果按照姓名排序ret…

开机性能-如何抓取开机systrace

一、理论 1.背景 抓取开机 trace 需要使用 userdebug 版本,而我们测试开机性能问题时都要求使用 user 版本,否则会有性能损耗问题。因此想要在抓取开机性能trace 时,需要在 user 版本上打开 atrace 功能之后才能抓取 trace,默认 …

SpringMVC文件上传、文件下载多文件上传及jrebel的使用与配置

一.文件上传 1.导入依赖 <dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.3.3</version> </dependency> 2.配置文件上传解析器 在spring-mvc.xml文件中添加文件…

蓝牙方案|伦茨科技最新ESL蓝牙电子价签方案

随着电子货架标签市场无线标准的发布&#xff0c;蓝牙技术将协助零售业进行下一阶段的数字化转型&#xff0c;为商店和购物者提供更好的消费体验。电子货架标签提供了精准的自动定价&#xff0c;并增加了对实时促销和产品信息的访问&#xff0c;提供更令人满意且整合的全渠道体…

Mqtt学习笔记--交叉编译移植(1)

简述 Mqtt目前在物联网行业的应用比较多&#xff0c;mqtt属于应用层的一个中间件&#xff0c;这个中间件实现消息的订阅发布机制。网上介绍Mqtt的实现原来的比较多&#xff0c;这里不细介绍。 其实在我们之前的产品中&#xff0c;自己也开发的有类似的中间件&#xff0c;除了具…