面试—MySQL

目录

多表查询

事务

存储引擎

索引结构

索引分类

SQL性能优化

索引失效

视图

存储过程

触发器

MySQL锁

全局锁

表锁

行锁


多表查询

分类

  1. 内连接

    只返回两个表符合条件的数据,相关联的数据(两个表的交集)

  2. 外连接

    • 左外连接以左表为基础,返回左表的数据以及右表中匹配的数据,如果查询不到右边数据,将列数据填为NULL

    左外连接,查询左表的数据以及交集数据

    右外连接,查询右表的数据以及交集数据

  3. 自连接

    将一个表看作两个表进行连接操作,可以是内连接也可以是外连接

联合查询

将查询结果合并成起来,查询的语句必须表字段一致

子查询

将查询的结果作为条件再次查询,嵌套查询

事务

  • 事务的四大特性

  1. 原子性,事务中的指令必须全部成功或者全部失败

  2. 隔离性,事务具有隔离性,执行事务不会被其他指令干扰

  3. 一致性,事务完成后,数据必须保证一致

  4. 持久性,事务一旦提交或者回滚,数据就会永久性发生变化

  • 并发事务

  1. 脏读,一个事务读取到了另一个事务还未提交更新的数据

  2. 不可重复读,一个事务先后读取同一个数据,数据不一致(另一个事务对数据进行了更新)

  3. 幻读,一个事务先查询数据发现不存在,但是在插入时数据已经存在(另一个事务先进行了插入)

  • 事务的隔离级别

  1. 读未提交(Read uncommitted),事务会读取到其他事务还未提交的数据,可能会造成

    脏读(事务A读取到事务B还未提交更新的数据,或事务B回滚数据,事务A读取到是错误数据)

    不可重复读

    幻读

  2. 读提交(Read committed),事务先后读取同一数据,数据可能不一致,可能造成

    不可重复读(事务A读取数据,一段时间后再次读取,但是事务B已经对数据进行了更新,此时事务A两次读取的数据不一样

    幻读(事务A想要执行插入数据,先去查询这个数据是否存在,查询到不存在,执行插入操作。但是事务B此时插入了这个数据,事务A无法在插入)

  3. 可重复读(Repeatable Read)(默认)

    MySQL默认隔离级别

    事务在先后读取数据,得到的数据是一致的,但是存在幻读问题

  4. 串行化(Serializable)

    最高隔离机制,事务不会受其他事务影响,按顺序执行事务。事务必须等待前一个事务执行完毕

存储引擎

  • MySQL体系结构

    连接层,当客户端发送连接请求时,进行连接处理(建立连接)

    服务层,存储最近查询的语句和结果,存入到数据缓存中。对SQL语句进行解析

    引擎层,负责数据的存储和处理

    存储层,磁盘IO操作,将数据存储到磁盘中

  • MySQL中的存储引擎

    1. InnoDB(Mysql默认引擎)

      • 支持事务,支持行锁,支持外键

      • 使用B+树索引结构

      • 存储逻辑分为:表空间>段>区(64个页)>页(索引中存放数据和指针 16K)>行(行数据)

    2. MyISAM

      • 不支持事务,不支持行锁,不支持外键,访问速度快,主要以读取数据和写入数据为主,很少对数据进行删除和修改

      MyISAM的索引和数据分开存储在不同的文件中,数据按插入顺序排列,顺序读取时访问速度快

      底层是B+树的索引结构,通过索引查找数据时更高效

      不支持事务,不用处理复杂的事务管理

      只支持表级锁,写入操作时会锁定整个表

    3. Memory

      • 内存存放是Hash索引,数据保存在内存中,访问速度快,常用于临时表和缓存

索引结构

索引结构主要是B+树索引和Hash索引

  1. 当树为二叉树时,顺序插入会形成一个链表,查询效率低

  2. 红黑树时,层级较深,检索速度慢

  3. B树的插入、检索效率都高

    以5阶为例,当一个页中存满4个元素时,插入元素会将这5个元素中的中间元素向上分裂。直到上面的页也存满,继续分裂

  4. B+树,基于B树,但叶子节点存放数据(单向链表),而非叶子节点只是起到一个索引数据的作用

    B树的页中存放的是数据和指针,而B+树只在叶子节点存放数据,在相同数据量下,层级比B+树高,检索的效率不如B+树

  5. 而InnoDB采用的就是B+树,同时对B+树的叶子节点进行优化,由单向链表优化为双向链表

  • Hash索引

    将键值对通过哈希函数计算出哈希值,映射到Hash表的槽位上

    如果出现哈希冲突,使用链地址法,插入链表末端

    1. 当根据一个字段查找时,会先计算这个字段的哈希值,根据哈希值找到哈希表中对应数据的位置

    2. 查找效率比B+树高,但是只能用于对等比较(=,in),不能范围查询(between,<,>)

索引分类

  1. 主键索引,针对字段中的主键

  2. 唯一索引,避免字段中的数据重复

  3. 常规索引,快速定位特点数据

  4. 全文索引,查找文本中的关键字

  • 在InnoDB中,主要是

  1. 聚集索引,主要是对主键,叶子节点存放的是行数据

  2. 二级索引,将数据和索引分开存储,叶子节点关联的是行的主键

  3. 再查找时,使用回表查询,如果根据二级索引区查找,会先查找叶子节点,对应的主键值,在进行对聚集索引根据主键值进行查找行数据

SQL性能优化

  1. SQL执行频率

    show global status like 'Com_______;'

    可以查看数据库的增删改查访问频次

  2. 慢查询日志

    在mysql的配置文件中开启慢查询日志,设置慢日志时间

    当sql语句执行时间超过慢日志时间就会被记录

  3. profile详情

    show profile可以查看每条SQL的耗时基本情况

  4. explain执行计划(常用)

    在sql语句前加explain关键字,可以查看sql语句可能用到的索引、实际用的索引等信息

索引失效

  1. 查询不遵循最左前缀法则

    创建的联合索引,在查询时必须保证最左边的字段被查询

    在联合索引中,从哪个字段断开,索引就从哪开始失效

  2. 范围查询

    在联合索引中,出现了范围查询,则范围右侧的列索引失效

  3. 索引列运行

    在索引列上进行运算操作,索引会失效

  4. 模糊查询

    如果是尾部模糊查询,则不会失效(软件%)

    如果是头部模糊查询,则索引失效(%工程)

  5. or连接的条件

    or连接的两个条件,如果是索引列和非索引列,则索引全部都失效

  6. 数据分布影响

    如果全表扫描的效率更好,则索引也会失效

视图

  • 视图是一个虚拟存在的表,基于一个表或多个表的查询结果创建,可以将复杂的查询语句封装到一个视图中(将查询多张表的复杂语句),用户只需对视图简单查询就可以得到结果(无需每次编写复杂语句)

  • 可以限制用户对敏感的数据进行访问,限制用户查看的权限

  • 如果底层的表的结构发送变化(字段、数据类型),只要视图可以正确的获取数据,就可以不对视图修改

存储过程

  • 存储过程是一组执行特点功能的SQL语句集,经过编译后存储在数据库中

  • 存储过程在数据库服务器上执行,客户端只需发送执行存储过程的请求就行,不需要发送大量SQL语句

  • 将复杂的业务逻辑写入存储过程中,业务逻辑发生变化,只需对存储过程修改,不需要修改多个地方的SQL语句

  • 存储过程相当于一个方法

触发器

  • 触发器是针对特点的数据库表

  • 事件触发时对表的增删改操作

  • 可以在触发器触发之前或者之后,执行一些操作(一组SQL语句)

MySQL锁

全局锁

  • 对整个数据库加锁,锁定数据库中所有的表,加锁后整个数据库都是只读状态

表锁

  • 对整个表进行加锁,分为表共享锁和表独占锁

  1. 表共享锁(read lock)

    加锁后,其他事务不可以对表执行写入操作,只能读取

  2. 表独占锁(write lock)

    加锁后,其他事务不可以多表执行写入和读取操作,相当于阻塞其他事务

行锁

  • 对表中的一行数据加锁

  • 当一个事务对一行数据加共享锁时,其他事务可以对这行数据加共享锁,不可以加排他锁。表示多个事务可以对一行数据进行读取,不能修改

  • 当一个事务对一行数据加排他锁时,其他事务可以对这行数据不可以加共享锁,也不可以加排他锁。表示一行数据只能由一个事务修改,其他事务只能等锁释放才能进行操作

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

无刷直流电动机的匝间绝缘测试优化

近年来&#xff0c;随着消费者对高效、快速干发需求的增加&#xff0c;高速电吹风逐渐成为市场的宠儿。高速电吹风的关键技术之一便是无刷直流电动机&#xff0c;其转速可以高达100,000转/分钟以上&#xff0c;电压为DC310V。相比传统电吹风&#xff0c;高速电吹风在效率和用户…

Prometheus 监控平台(Prometheus Monitoring Platform)

&#x1f49d;&#x1f49d;&#x1f49d;欢迎来到我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:Linux运维老纪的首页…

灰光模块,彩光模块-介绍

1. 引用 知识分享系列一&#xff1a;5G基础知识-CSDN博客 5G前传的最新进展-CSDN博客 灰光和彩光_通信行业5G招标系列点评之二&#xff1a;一文读懂5G前传-光纤、灰光、彩光、CWDM、LWDM、MWDM...-CSDN博客 ADOP带你了解&#xff1a;CWDM、DWDM、MWDM、LWDM&#xff1a;快速…

ffmpeg实现视频的合成与分割

视频合成与分割程序使用 作者开发了一款软件&#xff0c;可以实现对视频的合成和分割&#xff0c;界面如下&#xff1a; 播放时&#xff0c;可以选择多个视频源&#xff1b;在选中“保存视频”情况下&#xff0c;会将多个视频源合成一个视频。如果只取一个视频源中一段视频…

jmeter之TPS计算公式

需求&#xff1a; 如何确定环境当中的TPS指标 PV:&#xff08;Page View&#xff09;即页面访问量&#xff0c;每打开一次页面PV计数1&#xff0c;刷新页面也是。PV只统计页面访问次 数。 UV(Unique Visitor),唯一访问用户数&#xff0c;用来衡量真实访问网站的用户数量。 一般…

基于matlab交通标志识别系统用的APP designer设计的gui界面 交互原理:bp神经网络-训练好图像处理有灰度化-二值化-颜色区域定位识别

基于MATLAB的交通标志识别系统是一个实用的工具&#xff0c;用于识别道路交通标志。该系统结合了图像处理技术和BP神经网络模型&#xff0c;可以在给定的图像中定位并识别交通标志。通过使用MATLAB的App Designer工具&#xff0c;系统还提供了一个交互式的图形用户界面&#xf…

OpenAI发布o1大模型,突破LLM推理极限,弥补了之前在数学、科学和代码方面的不足

在北京时间9月13日凌晨&#xff0c;OpenAI正式发布了一系列全新的AI大模型【o1-preview 和 o1-mini】&#xff0c;专门针对复杂问题的解决。这一发布标志着一次重要的突破&#xff0c;新模型能够实现复杂的推理能力&#xff0c;通用模型在解决科学、代码和数学等领域中的难题方…

Linux 防火墙:iptables (一)

文章目录 iptables 概述netfilter 与 iptables 的关系 四表五链规则表规则链数据包处理的优先顺序与规则链匹配顺序规则表的优先顺序规则链的匹配顺序规则链内的匹配顺序匹配流程示意图 安装与格式iptables 的安装iptables 防火墙的配置方法iptables 命令行配置方法常用的控制类…

TestCraft - GPT支持的测试想法生成器和自动化测试生成器

在当今快速变化的软件开发世界中&#xff0c;自动化测试已成为确保软件质量的关键环节。而随着AI技术的进步&#xff0c;越来越多的工具开始引入人工智能&#xff0c;来辅助生成测试用例和自动化测试脚本。其中&#xff0c;TestCraft&#xff0c;作为一款GPT支持的测试想法生成…

【数据结构】双向链表专题

目录 1.双向链表的结构 2.双向链表的实现 2.1初始化 以参数的形式初始化链表&#xff1a; 以返回值的形式初始化链表&#xff1a; 2.2尾插 2.3打印 2.4头插 2.5尾删 2.6头删 2.7查找 2.8在指定位置之后插入数据​编辑 2.9删除pos节点 2.10销毁 3.整理代码 3.1…

Unity笔记:ScrollRect代码阅读

大体流程 Unity Docs - UGUI | Class ScrollRect 总的说 自身不负责Rebuild&#xff0c;设置脏之后交由LayoutRebuilder注册到CanvasUpdateRegistry里待rebuild的集合在固定时机统一Rebuild。自身只在Prelayout和Postlayout做一下数据准备和数据更新 自身的ICanvasElement.…

Visual Studio配置opencv环境

&#xff08;1&#xff09;打开属性页面&#xff08;鼠标放在解决方案上&#xff0c;点击右键会有一个属性选项弹出&#xff09; &#xff08;2&#xff09;配置opencv的include和opencv2路径&#xff0c;具体路径和版本根据自己电脑配置 &#xff08;3&#xff09;配置opencv…

OpenAI o1预览模型发布:推理能力更强 可达理科博士生水准

今日凌晨&#xff0c;OpenAI正式推出了OpenAI o1预览模型。 对于复杂推理任务而言&#xff0c;新模型代表着人工智能能力的崭新水平&#xff0c;其特点就是会在回答之前花更多时间进行思考&#xff0c;就像人类思考解决问题的过程一样。 OpenAI曾解释过&#xff0c;2023年发布…

卡车配置一键启动无钥匙进入手机控车

‌ 卡车智能一键启动无钥匙进入手机控车&#xff0c;通过手机应用程序与汽车内置硬件、软件的无线通信&#xff0c;实现对汽车的远程控制‌。 卡车改装一键启动的步骤包括安装门把手的感应装置、拆卸仪表台和门板&#xff0c;取出内部的待接线束&#xff0c;并将一键启动…

ip地址a段b段c段是什么意思

在互联网的世界里&#xff0c;每一个设备都需要一个独特的标识符来相互识别和通信&#xff0c;这就是IP地址。IP地址不仅仅是一串数字&#xff0c;它背后隐藏着网络的组织结构和设备的连接方式。本文将深入探讨IP地址中的A段、B段、C段的含义&#xff0c;以及它们在网络通信中的…

VSCode创建项目和编译多文件

前言 在刚安装好VSCode后&#xff0c;我简单尝试了仅main.cpp单文件编译代码&#xff0c;没有问题&#xff0c;但是当我尝试多文件编译时&#xff0c;就出现了无法识别cpp文件。 内容 创建项目 首先点击左上角“文件”&#xff1b;在菜单中选择“打开文件夹”&#xff1b;在…

建材家居家具电器整站网站打包下载预览图及地址二

木质装饰材料网站模板_建材家居家具电器类下载有预览图在博客首页.zip 响应式高端品牌建材陶瓷瓷砖网站模板_建材家居家具电器类下载有预览图在博客首页.zip 响应式创意家居网站模板_建材家居家具电器类下载有预览图在博客首页.zip 木纹地板墙砖类网站模板_建材家居家具电器…

极狐GitLab CI/CD 作业一直处于等待状态,如何解决?

本分分享 GitLab CI/CD Job 不工作的的故障排查方法&#xff1a;当 GitLab Runner 不接受 Job&#xff0c;Job 一直处于等待状态&#xff0c;如何解决此问题。 极狐GitLab 为 GitLab 在中国的发行版&#xff0c;中文版本对中国用户更友好。极狐GitLab 支持一键私有化部署&…

加密与安全_ sm-crypto 国密算法sm2、sm3和sm4的Java库

文章目录 Presm-crypto如何使用如何引入依赖 sm2获取密钥对加密解密签名验签获取椭圆曲线点 sm3sm4加密解密 Pre 加密与安全_三种方式实现基于国密非对称加密算法的加解密和签名验签 sm-crypto https://github.com/antherd/sm-crypto 国密算法sm2、sm3和sm4的java版。基于js…

linux入门到实操-4 linux系统网络配置、连接测试、网络连接模式、修改静态IP、配置主机名

教程来源&#xff1a;B站视频BV1WY4y1H7d3 3天搞定Linux&#xff0c;1天搞定Shell&#xff0c;清华学神带你通关_哔哩哔哩_bilibili 整理汇总的课程内容笔记和课程资料&#xff08;包含课程同版本linux系统文件等内容&#xff09;&#xff0c;供大家学习交流下载&#xff1a;…