MySQL面试题补

news2024/11/25 1:22:57

内连接和外连接的区别:


○1.功能和用法不同:内连接是连接两表都满足情况的数据;而外连接是以一边的表为主表,另一个表只显示匹配的行;
○2.用途:内连接一般是用于检索不同表需要根据共同的列值进行匹配的;而外连接要保留一个表的数据,其他表需要查询匹配的记录;
○3.性能:内连接的性能要优于外连接;因为内连接处理的记录少;


on、where、having区别

on是用于表连接的筛选条件,实在表进行连接时起作用; where是用于将结果集根据条件进行过滤操作;无法跟随聚合函数,用在将表查询完成之后; having是对分组之后的结果集进行过滤操作,可以使用聚合函数;


什么是笛卡尔积

在数据库中就是连接表是没有连接条件,导致返回的结果集是所有的数据;


链表查询有哪些优化操作注意事项?

1.对于连接条件可以使用合适的索引;

2.可以对查询字段使用索引,尽量不要使用select ,内存放不下;

3.小表驱动大表原理:让数据量较少的表作为驱动表去连接数据量大的表,以减少查询过程中需要扫描的数据量;


MySQL内存缓存:


MySQL内存缓存是一种机制,用于存储查询结果并加速读取操作。通过将完整的查询语句及其结果存储在内存中,MySQL内存缓存可以在下次相同查询请求时直接返回缓存的结果,而不必再次执行查询过程。这样可以减少对磁盘和数据库引擎的访问,提高响应速度和整体性能。
在MySQL中,有两种常见的内存缓存机制:
1.查询缓存(Query Cache):这是MySQL提供的一种内置缓存机制,用于缓存查询结果。当执行一个查询语句时,MySQL会先检查查询缓存中是否有对应的结果。如果有,则直接返回缓存结果;否则,执行查询并将结果存入缓存。查询缓存可以避免多次执行相同查询造成的性能损耗。但请注意,从MySQL 8.0版本开始,查询缓存功能已被弃用。
2.InnoDB缓冲池(Buffer Pool):对于使用InnoDB存储引擎的MySQL数据库,InnoDB缓冲池是一种重要的内存缓存机制。它用于缓存数据和索引,以便更快地访问这些数据。当数据库需要读取或写入数据时,它首先会尝试在缓冲池中找到这些数据。如果找到了,就可以直接在内存中完成操作,而无需访问磁盘。这样可以大大提高数据库的性能。


连表查询的底层原理?


首先说明驱动表(主表)和非驱动表(从表)
内连接:一般是通过查询优化器决定的;
左连接:一般是左边的表为主表,右边的表为从表;
右连接:一般是右边的表为主表,左边的表为从表;
了解了驱动表和被驱动表以后,现在我们看下MySQL究竟是怎么做join查询的。
简单嵌套循环连接(当然MySQL默认没有采用这种算法。) 简单嵌套循环连接(Simple Nested-Loop join)是从驱动表A中取出一条数据,遍历表B,将匹配到的数据放到result.. 以此类推, 如下图所示:

算法简单粗暴,比如驱动表A有10条,被驱动表B有100条,那么扫描次数是A+A*B, 每一次扫描其实就是从硬盘中读取数据加载到内存中,也就是一次IO,而IO是最大的瓶颈,所以效率低下。


块嵌套循环连接(引入了join buffer) 块嵌套循环连接(Block Nested-Loop Join)是对上面一种算法的优化,引入了join buffer缓冲区,将驱动表join相关的部分数据列、缓存到join buffer中,然后全表扫描被驱动表,被驱动表的每一条记录一次性和join buffer中的所有驱动表记录进行匹配(内存中操作),将简单嵌套循环中的多次比较合并成一次,降低了被驱动表的访问频率。

索索引嵌套循环连接
索引嵌套循环连接(Index Nested-Loop Join)就是效率最高的,前提条件是被驱动表的关联字段建立了索引。通过驱动表匹配条件直接与被驱动表的索引进行匹配,避免和内存表的每条记录去进行比较,这样极大的减少了对内存表的匹配次数。

Hash Join(MySQL 8) 从MySQL8后面的版本开始废弃块嵌套循环连接,默认使用了Hash Join的方式。
Hash Join算法利用哈希表来实现和加速数据库中的join操作。Hash Join的基本原理是将其中一个表(通常称为“构建表”)加载到内存中,并生成哈希表。然后,对另一个表(通常称为“扫描表”)进行扫描,匹配哈希表中的数据,最终得到连接结果。这种方式在当其中一个表较小或者可以完全缓存到内存中时,效率较高。Hash Join只能应用于等值连接,这是由Hash的特点决定的。


MySQL的数据是如何存储到磁盘的?


MySQL中的每个数据库都存储为文件系统上的目录,每个表存储为一个单独文件,mysql存储在磁盘中不是以行数据为单位的,而是以数据页为单位的,一页数据默认是16KB。存储多行数据,数据之间通过双向链表进行连接,页之间也通过链表进行连接。
行溢出:一个页的大小就是16KB,大于这个值就是行溢出;
数据页:一个数据页的上限是16K;


表到底是什么概念?


表(Table)是数据库的核心组件之一,用于存储和组织数据。表是一个二维的数据结构,由行(Row)和列(Column)组成。每一列代表一个特定的数据类型(如整数、字符串、日期等),而每一行则包含了一组与这些列相对应的数据值。
逻辑上是表,物理上是什么?
物理上实际就是数据页;


ACID事务特性以及隔离级别?


原子性
事务是一个不可分割的工作单元,事务中的操作要么全部发生,要么全部不发生;如果一部分成功,一部分失败,那么就进行回滚操作;
实现:原子性依靠undolog回滚日志实现,每次对数据进行修改和删除插入的操作都会生成一条undolog来记录操作之前的数据状态,使用rollback将执行的sql语句效果进行撤销操作;
一致性
事务前后的数据完整性一致;
实现:依靠的是其他三个特性实现的;
隔离性:
保证事务不被其他事务的并发操作环境干扰,多个并发事务之间要相互隔离;
实现:通过锁机制实现的,事务对数据操作的时候对数据加锁,保证事务操作数据的前后看到的数据是一致的;
持久性
指的是事务一旦被提交,那么他对数据的改变就是永久的;
实现:通过redo log实现,redo log记录的是对数据库的操作;


OLTP与OLAP的区别?


oltp(联机事务处理):是传统的关系型数据库的主要应用,用于基本的、日常的事务处理,例如银行的交易记录;
olap(联机分析处理):是数据仓库系统的主要应用,支持复杂的分析操作,侧重决策支持,并且提供了直观易懂的查询结果,。常见的应用是复杂的动态报表系统;
总体来说,OLTP用于日常处理、OLAP用于数据分析。


DML是什么呢?


dml是数据操作语言,用于检索或者修改数据,我们平常所说的增删改查就属于dml;


ddl是什么?


ddl是数据定义语言,用于操作数据结构,例如创建表,删除表,更改索引等;


DCL是什么?


数据控制语言,用于定义数据库用户的权限,比如创建用户,授权用户,删除用户等都是DCL。


能说说varchar与char的区别是什么吗?


char是一种固定长度的类型,varchar则是一种可变长度的类型。比如char(128)和varchar(128),前者无论字符串长短,在磁盘上,都会占据固定的128字符大小。后者是可变长度,不过它最大也不能超过128。


既然varchar是变长,那是不是设置varchar(1000)一定比varchar(100)好?


不是这样的。虽然varchar是变长,在相同长度下,磁盘空间占用一样,将值设置更大一些,弹性空间也更大。但也不是完全没有代价的
在内存加载的时候,每次都是按最大空间来分配的。显然,在排序场景,或者一些临时表聚合场景,更大空间会产生明显的不利影响。


varchar是变长,char是定长,那能用varchar完全代替char么?

varchar的优点是更灵活。但是char也不是一无是处的。
首先,varchar会额外用一个字节存储长度信息,而char则节约了一个字节;
其次,char的存储空间都是一次性分配的,存储是固定连续的,而varchar的存储的长度是可变的,当varchar更改前后数据长度不一致时,就不可避免的会出现碎片的问题。针对此,需要进行碎片消除作业,也是额外的成本。
一般来说,长度固定的字段,还是用char比较合适,比如Hash,就很适合用char。


varchar(11)和int(11)中的50,有什么区别?


varcahr中代表能存11个字符,int中只是代表显示长度,对大多数应用没有意义,只是规定一些工具用来显示字符的个数,比如int(1)和int(20)存储和计算其实是一样的。


接下来能说说delete和truncate的区别吗?


delete是删除行;truncate是整表删除。具体来说,有下面几点区别:
1.truncate之后,会释放空间;delete之后,不会释放空间,因为delete只是在行上标记删除,后续可以复用;
2.delete因为是DML,会产生redo log;truncate是DDL则不会;
3.truncate效率更高;
4.truncate之后,id从头开始;delete不会。


你知道MySQL有哪些存储引擎吗?


首先有Innodb引擎,它提供了对数据库ACID事务的支持,并且还提供了行级锁和外键的约束。Innodb的设计目标就是处理大数据容量的数据库系统; 还有MyIASM引擎,它是原本Mysql的默认引擎,不提供事务的支持,也不支持行级锁和外键; 最后还有一个MEMORY引擎,它的所有数据都在内存中,数据的处理速度快,但是安全性不高,很少使用。 那么ACID是什么呢? 它是原子性、一致性、隔离性和持久性的缩写。


主键和外键分别是什么?

主键是表中的一个或多个字段,它的值用于唯一的标识表中的某一条记录。
外键是说某张表b的主键,在另一张表a中被使用,那么a中该字段可以使用的范围,取决于b。外键约束主要用来维护两个表之间数据的一致性。

那么一张表一定有主键吗?


是的。一定有。如果主动设置,则采用设置的。否则会自动生成一个默认的行。


你怎么查看有多少个Sql语句在执行?


可以用show processlist,它是显示用户正在运行的线程的命令。需要注意的是,用户都只能看到自己正在运行的线程,除非是root用户,或者专门进行了授权的用户。


 

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

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

相关文章

查看浏览器的请求头

爬虫时用到了请求头,虽然可以用网上公开的,但是还是想了解一下本机浏览器的。以 Edge 为例,其余浏览器通用。 打开浏览器任一网页,按F12打开DevTools;或鼠标右键,选择“检查”。首次打开界面应该显示在网页…

小R的二叉树探险 | 模拟

问题描述 在一个神奇的二叉树中,结构非常独特: 每层的节点值赋值方向是交替的,第一层从左到右,第二层从右到左,以此类推,且该二叉树有无穷多层。 小R对这个二叉树充满了好奇,她想知道&#xf…

蓝牙定位|三维空间情况下的仿真例程(四个蓝牙基站的情况,附源代码)MATLAB程序

这段代码通过RSSI信号强度实现了在三维空间中的蓝牙定位,展示了如何使用锚点位置和测量的信号强度来估计未知点的位置。代码涉及信号衰减模型、距离计算和最小二乘法估计等基本概念,并通过三维可视化展示了真实位置与估计位置的关系。 文章目录 蓝牙定位…

Banana Pi BPI-CanMV-K230D-Zero 采用嘉楠科技 K230D RISC-V芯片设计

概述 Banana Pi BPI-CanMV-K230D-Zero 采用嘉楠科技 K230D RISC-V芯片设计,探索 RISC-V Vector1.0 的前沿技术,选择嘉楠科技的 Canmv K230D Zero 开发板。这款创新的开发板是由嘉楠科技与香蕉派开源社区联合设计研发,搭载了先进的勘智 K230D 芯片。 K230…

Django+Nginx+uwsgi网站使用Channels+redis+daphne实现简单的多人在线聊天及消息存储功能

网站部署在华为云服务器上,Debian系统,使用DjangoNginxuwsgi搭建。最终效果如下图所示。 一、响应逻辑顺序 1. 聊天页面请求 客户端请求/chat/(输入聊天室房间号界面)和/chat/room_name(某个聊天室页面)链…

TransFormer--整合编码器和解码器

TransFormer--整合编码器和解码器 下图完整地展示了带有编码器和解码器的Transformer架构。 在图中,N表示可以堆叠N个编码器和解码器。我们可以看到,一旦输入句子(原句),编码器就会学习其特征并将特征发送给解码器&…

短视频矩阵矩阵,矩阵号策略

随着数字媒体的迅猛发展,短视频平台已经成为企业和个人品牌推广的核心渠道。在这一背景下,短视频矩阵营销策略应运而生,它通过高效整合和管理多个短视频账号,实现资源的最优配置和营销效果的最大化。本文旨在深入探讨短视频矩阵的…

Apple Vision Pro开发002-新建项目配置

一、新建项目 可以选择默认的,也可以选择Universal 3D 二、切换打包平台 注意选择Target SDK为Devices SDk,这种适配打包到真机调试 三、升级新的Input系统 打开ProjectSettings,替换完毕之后引擎会重启 四、导入PolySpatial 修改上图红…

【StarRocks】starrocks 3.2.12 【share-nothing】 多Be集群容器化部署

文章目录 一. 集群规划二.docker compose以及启动脚本卷映射对于网络环境变量 三. 集群测试用户新建、赋权、库表初始化断电重启扩容 BE 集群 一. 集群规划 部署文档 https://docs.starrocks.io/zh/docs/2.5/deployment/plan_cluster/ 分类描述FE节点1. 主要负责元数据管理、…

LLaMA-Factory 上手即用教程

LLaMA-Factory 是一个高效的大型语言模型微调工具,支持多种模型和训练方法,包括预训练、监督微调、强化学习等,同时提供量化技术和实验监控,旨在提高训练速度和模型性能。 官方开源地址:https://github.com/hiyouga/L…

Java基础面试题01-请描述Java中JDK和JRE的区别?

什么是 JDK? JDK 全称 Java Development Kit,中文叫“Java 开发工具包”。 它是给 Java 开发者用的工具箱,里面有一切写代码、编译代码、调试代码所需要的工具。 JDK 包括什么? Java 编译器(javac)&…

Ubuntu20.04下安装向日葵

向日葵远程控制app官方下载 - 贝锐向日葵官网 下载Ununtu版的图形版本的安装deb包SunloginClient_15.2.0.63064_amd64.deb 直接执行 sudo dpkg -i SunloginClient_15.2.0.63064_amd64.deb 的话会报错: 如果在Ubuntu20.04里直接执行sudo apt install libgconf-2-4安装libgco…

Typora+PicGo+云服务器搭建博客图床

文章目录 前言一. 为什么要搭建博客图床?1.1 什么是图床?1.2 为什么要搭建博客图床? 二. 安装软件三. 配置阿里云OSS3.1 注册,开通对象储存3.2 创建bucket3.3 找到你的地域节点3.4 accessKeyId和accessKeySecret3.5 给你的阿里云账户充值 四. 配置4.1 配…

Python的3D可视化库 - vedo (2)visual子模块 基本可视化行为

文章目录 1. visual模块的继承关系2. 基类CommonVisual的方法2.1 获取对象信息2.1.1 对象本身信息2.1.2 对象的查找表2.1.3 对象标量范围2.1.4 对象缩略图 2.2 呈现对象2.2.1 在窗口显示1.2.2 对象可见性 2.2.3 对象颜色2.2.4 对象透明度 2.3 添加标度条2.3.1 2D标度条2.3.2 3D…

常用Rust日志处理工具教程

在本文中,我想讨论Rust中的日志。通过一些背景信息,我将带您了解两个日志库:env_logger和log4rs。最后,我将分享我的建议和github的片段。 Rust log介绍 log包是Rust中日志API的事实标准,共有五个日志级别&#xff1…

废品买卖回收管理系统|Java|SSM|Vue| 前后端分离

【重要①】前后端源码万字文档部署文档 【重要②】正版源码有问题包售后 【包含内容】 【一】项目提供非常完整的源码注释 【二】相关技术栈文档 【三】源码讲解视频 【其它服务】 【一】可以提供远程部署安装,包扩环境 【…

案例研究|阿特斯的JumpServer分布式部署和多组织管理实践

苏州阿特斯阳光电力科技有限公司(以下简称为阿特斯)是一家集太阳能光伏组件制造和为全球客户提供太阳能应用产品研发、设计、制造、销售的专业公司。 阿特斯集团总部位于加拿大,中国区总部位于江苏省苏州市。通过全球战略和多元化的市场布局…

tongweb安全整改

一 禁止以root账号运行tongweb服务 1 如果是首次安装须创建普通用户安装tongweb 2 如果已经使用root账号安装了tongweb 2.1 创建普通用户 2.2 使用root账号授予tongweb安装目录宿主权限为普通用户 2.3赋权成功后,后续启动tongweb服务必须为普通用户 二 tongRDS隐…

快速识别模型:simple_ocr,部署教程

快速识别图片中的英文、标点符号、数学符号、Emoji, 模型会输出图片中文字行的坐标位置、最低得分、识别结果。当前服务用到的模型:检测模型、数字识别、英文符号识别。 一、部署流程 1.更新基础环境 apt update2.安装miniconda wget https://repo.anaconda.com/…

tcpdump抓包 wireShark

TCPdump抓包工具介绍 TCPdump,全称dump the traffic on anetwork,是一个运行在linux平台可以根据使用者需求对网络上传输的数据包进行捕获的抓包工具。 tcpdump可以支持的功能: 1、在Linux平台将网络中传输的数据包全部捕获过来进行分析 2、支持网络层…