MySQL重点,面试题

news2024/9/27 11:39:54

请添加图片描述请添加图片描述

一、 聚合函数

分类

  1. COUNT:统计行数量
  2. SUM:获取单个列的合计值
  3. AVG:计算某个列的平均值
  4. MAX:计算列的最大值
  5. MIN:计算列的最小值

请添加图片描述
请添加图片描述

二、SQL关键字

  1. 分页:limit
    SELECT * FROM student limit 100,6; 倒序 desc select * from user order by id desc limit 0 6
  2. 分组:group by
    SELECT sex , count(*) FROM student group by sex
  3. 去重:distinct
    select distinct name FROM student;

三、SQL Select 语句完整的执行顺序

from
left join
on
where
group by
having
select
avg()/sum()
order by
asc/desc
limit

四、数据库三大范式

第一范式

1NF 原子性,不可再分

第二范式

2NF 唯一标识 主要解决的冗余

  1. 每一行数据有唯一主键
  2. 非关键字必须依赖于主键字段

第三范式

3NF 直接性,非主键字段不依赖于其它非主键字段,主要解决的冗余
在使用时有时会打破第三范式
保留冗余字段。当两个或多个表在查询中经常需要连接时,可以在其中一个表上增加若干冗余的字段,以 避免表之间的连接过于频繁

五、存储引擎

MyISAM 存储引擎 与 InnoDB 引擎区别

  1. 事务支持:MyISAM不支持,InnoDB支持,通过事务确保数据完整性和一致性
  2. 锁定机制:MyISAM 表级锁,读操作会被阻塞,InnoDB 行级锁,可以减少锁定冲突和死锁的发生
  3. 外键支持:MyISAM不支持外键约束,InnoDB支持外键约束,可以通过外键约束保证数据的引用完整性
  4. 并发性能:InnoDB更优

六、数据库事务

1.事务特性(ACID)

  1. 原子性
  2. 一致性
  3. 隔离性
  4. 持久性
    undo_log 解决原子性和一致性
    redo_log解决持久性 记录写操作,Mysql异常关闭时会重新加载写操作恢复数据,保证数据持久性

2、隔离级别

  1. 读未提交:所有事务可能读取到别的事物的未提交数据,会造成脏读问题
  2. 读已提交:针对update和delete,其他事物修改了相应的数据,同一个事务多个查询语句可能返回不同结果,能看到别的事务提交时的数据,出现不可重复读问题
  3. 可重复读:针对insert,默认隔离机制,确保一个事物中多个实例在并发读取数据的时候读到一样的数据,会导致幻读
  4. 可串行化:可避免上述问题,但是效率很慢

七、索引

1. 索引的概念和优点

主要作用加快数据查找速度,提高数据库性能

优点:加快查询效率
缺点:占用内存空间,影响增删改,效率低下

2. 索引分类

  1. 普通索引,没有任何限制
  2. 唯一索引:索引列的值必须唯一,允许有空值,如会员表的手机号,身份证号
  3. 主键索引:特殊的唯一索引,唯一标记数据表中的某一记录,不允许有空值,一般用primary key约束
  4. 联合索引:多个字段上建立索引,能快速符合查询条件的检索,如手机号和密码,会员ID和订单ID,商品表分类状态
  5. 全文索引:默认不支持中文全文索引,可通过扩展MySQL,添加中文全文索引

3.索引的底层实现原理

索引是在Mysql的存储引擎层中实现,不是在服务层实现
MySQL目前支持四种索引:

  1. B+ Tree索引:最常见的索引类型,大部分索引都支持
  2. Hash索引:只有Memory引擎支持,使用场景简单
  3. R- Tree索引:空间索引,是MySQL引擎中的特殊索引
  4. S-Full-text(全文索引):MySQL引擎的特殊索引
    请添加图片描述

B树和B+树的主要区别

  1. 存储数据的位置:
    B树:数据存储到所有节点
    B+树:所有数据存储在叶子节点中,非叶子节点仅包含索引信息
  2. 叶子节点之间的链接:
    B树:叶子节点之间没有链接
    B+树:叶子节点之间通过 指针相互链接,范围查询和遍历更高效

4. 如何避免索引失效

  1. 范围条件查询
  2. 索引列上操作导致索引失效(函数)
  3. 字符串不加引号
  4. or关键字连接
  5. 使用 !=
  6. like通配符开头(‘%abc…’)

八、 数据库锁

1.行锁和表锁

行锁:访问数据库时,锁定整个行数据
表锁:访问数据库时,锁定整个表数据

行锁和表锁的区别

表锁:开销小,加锁快,不会出现死锁,锁定力度大,发生锁冲突概率高,并发度最低
行锁:开销大,加锁慢,会出现死锁,锁定力度小,发生锁冲突概率低,并发度高

2.悲观锁和乐观锁

悲观锁,每次拿到数据都加锁,效率低
乐观锁,拿到数据不会加锁,在更新时判断数据有没有更新,适用于多读的应用类型,可提高吞吐量,可以使用版本号机制

九、MySQL优化

  1. 定位执行效率慢的sql语句
  2. 优化索引
  3. sql语句调优
  4. 合理的数据库设计

定位效率慢的sql语句

  1. skywallKing查看日志
  2. explain + sql语句查询sql执行过程, 可以查看查找的sql语句是否走索引
  3. show profile 分析 SQL,可以查询到所有 sql 语句的执行效率
  4. 慢查询日志工具

优化索引的方法:

  1. 查询频次较高,并且数据量较大的表,建立索引
  2. 选择最常用的索引字段
  3. 使用唯一索引
  4. 索引不是越多越好,过多索引会降低表维护效率
  5. 使用短索引,提高索引访问时的I/O效率,提升Mysql查询效率
  6. where后有多个条件时,建立复合索引,需遵循最左前缀法则

sql语句调优方法

  1. 根据业务建立复合索引只查询需要的字段
  2. 多表连接的字段需要建立索引
  3. where条件字段需要建立索引,where条件不要使用运算函数
  4. 排序字段加索引提高查询效率
  5. 优化order by语句,不使用select *
  6. 优化group by语句,默认排序,使用时可以禁止排序
  7. 尽量避免子查询,可以优化为join多表连接查询

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

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

相关文章

数据结构 ——— 移除 nums 数组中的 val 元素(快慢指针)

目录 题目要求 代码实现(快慢指针) 题目要求 编写函数,给你一个数组 nums 和一个值 val,你需要在 nums 数组 原地 移除所有数值等于 val 的元素,并且返回移除后数组的新长度 不能使用额外的数组空间,要…

11.全面学习面向对象技术

面向对象开发 相关概念 对象:由数据及其操作所构成的封装体,是系统中用来描述客观事务的一个实体,是构成系统的一个基本单位。一个对象通常可以由对象名、属性和方法3个部分组成。类:现实世界中实体的形式化描述,类…

MySQL_插入、更新和删除数据

课 程 推 荐我 的 个 人 主 页:👉👉 失心疯的个人主页 👈👈入 门 教 程 推 荐 :👉👉 Python零基础入门教程合集 👈👈虚 拟 环 境 搭 建 :&#x1…

如何禁止电脑蓝牙?五个有效方法教给你!小白必看!

在生活和工作中,蓝牙是一种非常方便的无线技术,可以连接鼠标、键盘、耳机等设备。 然而,蓝牙同时也是信息泄露的潜在渠道,特别是在公共场所或公司内部环境中,可能会带来安全隐患。 想要保护隐私或防止电脑与未经授权…

基于YOLOv8目标检测与chef-transformer(T5)从图像创建食谱

前言 在本文中,将演示如何使用从Roboflow获得的开源产品数据来训练我的YOLOv8模型,然后将其与从Hugging Face获得的chef-transformer(T5)模型集成。应用程序的主要目标是将检测到的对象参数化地发送到语言模型,并在NL…

第05-3节:加载流程原理介绍(Done)

我的后端学习大纲 我的Linux学习大纲 本节目标 1.能够说出交互式Shell与非交互式Shell2.能够说出登录Shell与非登录Shell环境 1.1.Shell工作环境介绍 用户进入linux系统就会初始化Shell环境, 这个环境会加载全局配置文件和用户个人配置文件中环境变量.每个脚本文件都有自己的…

STM32嵌入式编程学习到提高:【4】UART串口打印

------------------------------------------------------------------------------------------------------------------------- 工程文件:放在百度云盘里,需要的自行下载!!! 链接: https://pan.baidu.com/s/14gRne…

2万字长文助你快速入门AIGC:包含底层原理、应用场景、热门工具、行业现状…

最近大家热议的ChatGPT和AI绘画工具的底层技术原理是什么?是如何发展到现在的?有哪些应用场景、热门工具?AIGC产业上下游有哪些公司?作为普通用户,我们还能接触哪些应用AI技术打造的商业解决方案?…… 我们…

RK 方案VOP 显示接口的链接关系以及DTS如何配置

这图显示各vp 支持情况 如下图VP0 支持DSI0 DSI1 EDP LVDS HDMI 显示接口,如果我们一方案需要点MIPI 屏 和HDMI out, 如果VP0 链接MIPI DSI0 那么VP0 就不能再选择了,只能VP1 链接HDMI out 了。因为VP2不至此HDMI,所有就只有选择VP1 链接HDMI…

随记——机器学习

前言 本来有个500块钱的单子,用机器学习做一个不知道什么鸟的识别,正好有数据集,跑个小项目,过一下机器学习图像识别的流程,用很短的时间记录下来..... 一、数据预处理 将数据集分为训练集和测试集,直接…

【HarmonyOS】SaveButton保存图片

SaveButton组件把图片显示到相册中的方法demo,支持组件截图、url网络图片、base64格式图片。注意事项: 1、不支持自定义SaveButton样式。 2、下载按钮被遮挡一部分,也无法保存到相册。 import photoAccessHelper from ohos.file.photoAcces…

使用 pypdf 给 PDF 添加目录书签

""" dir.txt的形式 第1章 计算机系统基础知识 1 1.1 嵌入式计算机系统概述 1 1.2 数据表示 4 1.2.1 进位计数制及转换 4 1.2.2 数值型数据的表示 6 第2章 嵌入式系统硬件基础知识 56 2.1 数字电路基础 56 2.1.1 信号特征 56 2.1.2 组合逻辑电路和时序逻辑电路 5…

为什么现在的网站设计大多都非常简洁,越来越扁平化

网站设计趋向简洁和扁平化,反映了现代设计理念的转变和技术的进步。以下是对这一现象的具体分析: 用户体验优先:用户更倾向于简单直接的界面,这有助于快速找到所需信息。扁平化设计通过减少视觉干扰,使得内容更加突出…

哪些因素会影响六西格玛效果的显现时间?

在探讨哪些因素会影响六西格玛效果的显现时间时,我们不得不深入剖析六西格玛管理方法的本质及其在企业中的实施过程。六西格玛作为一种旨在通过减少缺陷和变异来提高产品和服务质量的策略,其成功实施并非一蹴而就,而是受到多种复杂因素的共同…

Llama 系列简介与 Llama3 预训练模型推理

1. Llama 系列简介 1.1 Llama1 由 Meta AI 发布,包含 7B、13B、33B 和 65B 四种参数规模的开源基座语言模型 数据集:模型训练数据集使用的都是开源的数据集,总共 1.4T token 模型结构:原始的 Transformer 由编码器&#xff08…

Git 与远程分支

90.远程仓库和分支 我们经常需要对远程仓库里的分支进行更新。 ‍ 当从远程库 clone 时,默认情况下,只会拉取 master ​分支,并且会将本地的 master 分支和远程的 master 分支关联起来: $ git branch * master‍ ‍ 推送本地…

什么是分布式缓存,它是如何工作的?

嗨,你好啊,我是猿java 在日常开发中,我们经常会使用到缓存,当数据集较小时,通常将所有缓存数据保存在一台服务器上就足够了,但是当数据集较大时,我们需要将缓存数据分布在多个服务器上&#xf…

无线领夹麦克风怎么挑选?选购麦克风需要注意的五大选购陷阱!

无线领夹麦克风只所以成为现在自媒体行业的主流拾音设备,很大程度取决于它的轻巧的设计以及便携性。相较于传统的手持麦克风,领夹麦在使用时无需手持,直接佩戴在衣领上即可使用,腾出的双手可以更好的投入到录制当中,在…

Python与SQL Server数据库结合导出Excel并做部分修改

Python与SQL Server数据库结合导出Excel并做部分修改 需求:在数据库中提取需要的字段内容;并根据字段内容来提取与拆分数据做为新的列最后导出到Excel文件 # -*- coding: utf-8 -*- import pandas as pd import re import pymssql import timestart_ti…

Activiti的Web在线工作流设计器的几种搭建方式

说明 Activiti Activiti是一个使用Java开发的工作流流程管理(BPM)平台,可以帮助开发者和企业自动化管理业务流程。它提供了一整套工具,用于定义、执行、监控和优化业务流程。Activiti支持BPMN 2.0标准,具有强大的扩展能力和易用性&#xff…