MySQL面试题 | 03.精选MySQL面试题

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6
🍨 阿珊和她的猫_CSDN个人主页
🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》
🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

    • 9. 什么是外键?有什么作用?
    • 10. MySQL 支持的数据类型有哪些?请列举一些常用的数据类型。
    • 11. 什么是事务?MySQL 如何处理事务?
    • 12. 解释 ACID 原则。

9. 什么是外键?有什么作用?

外键(Foreign Key)是一个数据库中用于关联两个表的约束,它用于保证两个表之间的数据完整性。外键通常包含一个或多个列,可以是复合外键(由多个列组成)

外键的作用主要有以下几个方面:

  1. 关联数据:外键关联两个表之间的数据,保证数据的完整性,即在删除或更新一个表中的记录时,必须先删除或更新关联表中的相应记录。
  2. 索引:外键是一个索引,可以加速数据的查询和更新操作。
  3. 约束:外键可以用于定义外键约束,从而保证外键列的值与主键列的值保持一致。

在 MySQL 中,每个表可以有一个或多个外键,但每个表只能有一个主键。外键可以用于定义主键约束,从而保证主键列的值与关联表的主键列的值保持一致。

外键可以用于定义不同表之间的关联关系,如一对多、多对一、多对多等。外键可以保证数据的完整性和一致性,同时可以提高查询效率。

10. MySQL 支持的数据类型有哪些?请列举一些常用的数据类型。

MySQL 支持的数据类型主要有以下几种:

  1. 整数类型:整数类型用于存储整数数据,如 INT、INTEGER、BIGINT、SMALLINT、TINYINT 等。
  2. 浮点类型:浮点类型用于存储浮点数数据,如 FLOAT、DOUBLE、DECIMAL、NUMERIC 等。
  3. 字符类型:字符类型用于存储字符串数据,如 CHAR、VARCHAR、NCHAR、NVARCHAR、LONGTEXT、TEXT、TINYTEXT 等。
  4. 日期和时间类型:日期和时间类型用于存储日期和时间数据,如 DATE、DATETIME、TIMESTAMP、TIME、YEAR 等。
  5. 枚举类型:枚举类型用于存储一组固定的值,如 ENUM、SET 等。
  6. 布尔类型:布尔类型用于存储布尔值,如 BOOLEAN、BOOL 等。
  7. 二进制类型:二进制类型用于存储二进制数据,如 BINARY、VARBINARY、TINYBLOB、MEDIUMBLOB、LONGBLOB 等。

以下是几个常用的数据类型:

  • INT:用于存储整数数据,默认值为 0,最大值为 2^31 - 1,最小值为 -2^31。
  • FLOAT:用于存储浮点数数据,默认值为 0.0,最大值为 1.7976931348623157E308,最小值为 -1.7976931348623157E308。
  • VARCHAR:用于存储变长的字符串数据,最大长度受限于 server 配置中的 max_allowed_packet 参数。
  • DATE:用于存储日期数据,格式为 ‘YYYY-MM-DD’。
  • DATETIME:用于存储日期和时间数据,格式为 ‘YYYY-MM-DD HH:MM:SS’。
  • BOOLEAN:用于存储布尔值,取值范围为 0 或 1。

11. 什么是事务?MySQL 如何处理事务?

事务(Transaction)是一个数据库操作的集合,用于确保数据的一致性和完整性。在 MySQL 中,事务可以通过 start transaction、commit 和 rollback 命令来控制。

事务的处理过程如下:

  1. start transaction:开始一个事务。
  2. 执行一系列数据库操作,例如插入、更新、删除等。
  3. commit:提交事务,将事务期间执行的所有数据库操作保存到磁盘。
  4. rollback:回滚事务,将事务期间执行的所有数据库操作撤销,回到事务开始前的状态。

MySQL 处理事务时遵循 ACID 原则,即原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability)。

  • 原子性:一个事务的所有数据库操作都是原子性的,要么全部成功,要么全部失败,不会出现部分成功部分失败的情况。
  • 一致性:事务执行过程中,数据库的完整性不会被破坏,数据始终保持一致。
  • 隔离性:每个事务可以看到的是数据库的一个快照,即在事务开始之前的数据库状态,不会受到其他事务的影响。
  • 持久性:事务结束后,数据库中的数据会被永久保存,即使数据库崩溃或重启,数据也不会丢失。

MySQL 支持多种事务隔离级别,如:

  • 读未提交(Read Uncommitted):允许一个事务在未提交的情况下读取其他事务的数据。
  • 读提交(Read Committed):允许一个事务在事务提交后读取其他事务的数据。
  • 事务提交(Transaction Isolated):允许一个事务在事务提交后读取其他事务的数据,但需要使用事务隔离级别进行隔离。

在 MySQL 中,默认的事务隔离级别为事务提交(Transaction Isolated),即事务提交后才能读取其他事务的数据。

12. 解释 ACID 原则。

ACID(Atomicity、Consistency、Isolation、Durability)是数据库管理系统(DBMS)中事务的四个关键属性,它们确保了数据库操作的完整性和一致性。

  1. Atomicity(原子性):一个事务的所有数据库操作都是原子性的,要么全部成功,要么全部失败,不会出现部分成功部分失败的情况。这可以确保事务的一致性和完整性。
  2. Consistency(一致性):事务执行过程中,数据库的完整性不会被破坏,数据始终保持一致。这可以确保数据的完整性。
  3. Isolation(隔离性):每个事务可以看到的是数据库的一个快照,即在事务开始之前的数据库状态,不会受到其他事务的影响。这可以确保事务隔离性。
  4. Durability(持久性):事务结束后,数据库中的数据会被永久保存,即使数据库崩溃或重启,数据也不会丢失。这可以确保数据的持久性。

ACID 原则是数据库管理系统中事务处理的基本准则,确保了数据库操作的安全性和一致性。

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

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

相关文章

如何做好项目进度估算?5个重点

在实际的IT 项目中,进度常常会出现延误的情况,其原因有很多。但是,我们需要关注一种情况,即我们的项目进度时间是如何估算出来的?是基于准确的数据和分析,还是由其他部门随意拍脑袋决定的?而进度…

Springboot + websocket 实现 一对一 单人聊天

Springboot websocket 实现 一对一 单人聊天 要使用websocket ,需要添加 jar 打开项目中的pom.xml,添加以下内容 创建java端代码 配置websocke的endpoints 配置websocket的server ServerEndpoint(value "/websocket/{username}") 这句话 一定要注意, 这里 路…

想成为一名C++开发工程师,需要具备哪些条件?

C语言是一门面向过程的、抽象化的通用程序设计语言,广泛应用于底层开发。C语言能以简易的方式编译、处理低级存储器。C语言是仅产生少量的机器语言以及不需要任何运行环境支持便能运行的高效率程序设计语言。尽管C语言提供了许多低级处理的功能,但仍然保…

[Vue]从数据库中动态加载阿里巴巴矢量图标的两种方式

记录一次在Vue中动态使用阿里巴巴矢量图标库 这是本人第一次使用阿里巴巴的矢量图标库,简单的导入和使用的话网上的教程很多,这里不多赘述,本人的需求是从数据库中加载出来并且显示到页面上,接下来简述一下如何实现。 以下代码均是…

【数据结构与算法】之数组系列-20240114

这里写目录标题 一、414. 第三大的数二、448. 找到所有数组中消失的数字三、561. 数组拆分四、594. 最长和谐子序列 一、414. 第三大的数 简单 给你一个非空数组,返回此数组中第三大的数。如果不存在,则返回数组中最大的数。 示例 1: 输入&…

阿里状态机引擎实现

状态机的技术选型看这篇就够了&#xff0c;最后一个直叫好&#xff01; - 掘金 实现一个状态机引擎&#xff0c;教你看清DSL的本质_cola状态机-CSDN博客 一、引入jar包 <!--阿里状态机jar--> <dependency><groupId>com.alibaba.cola</groupId><a…

大创项目推荐 深度学习疲劳检测 驾驶行为检测 - python opencv cnn

文章目录 0 前言1 课题背景2 相关技术2.1 Dlib人脸识别库2.2 疲劳检测算法2.3 YOLOV5算法 3 效果展示3.1 眨眼3.2 打哈欠3.3 使用手机检测3.4 抽烟检测3.5 喝水检测 4 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; **基于深度学习加…

虚拟机配置固定IP

1.DHCP 当前我们虚拟机的Linux操作系统&#xff0c;其IP地址是通过DHCP服务获取的。 DHCP&#xff1a;动态获取IP地址&#xff0c;即每次重启设备后都会获取一次&#xff0c;可能导致IP地址频繁变更&#xff0c;这就会给我们带来不方便&#xff0c;因为如果我们每次重启设备都…

2024年AMC8模拟考试实测流程、注意事项和常见问题

和往年的AMC8比赛一样&#xff0c;在正式比赛的前一周左右会开放两天的模拟考试时间&#xff0c;AMC8的主办方建议所有的参赛选手重视且参加模拟考试&#xff0c;以测试设备、熟悉流程&#xff0c;避免将来正式考试不小心违规&#xff0c;或者设备不给力。 2024年的AMC8模拟考…

线性代数——(期末突击)概率统计习题(概率的性质、全概率公式)

目录 概率的性质 题一 全概率公式 题二 题三 概率的性质 有限可加性&#xff1a; 若有限个事件互不相容&#xff0c;则 单调性&#xff1a; 互补性&#xff1a; 加法公式&#xff1a; 可分性&#xff1a; 题一 在某城市中共发行三种报纸&#xff1a;甲、乙、丙。在这个…

Flutter之运行错误:Error: Member notfound: ‘SystemChrome .setEnabledSystemuIOverlays‘

项目由于引入的包导致报错&#xff1a; Error: Member notfound: SystemChrome .setEnabledSystemuIOverlays 主要原因是因为包里的方法有变动。 解决办法&#xff1a; 将AppDate\Local\Pub\Cache\hosted\pub.dev\r_scan-0.1.61\lib\src\r_scan_view.dart文件中的 原方法&am…

设计模式——1_4 外观(Facade)

文章目录 定义图纸一个例子&#xff1a;自动生成一杯茶沏茶的流程组合方式一&#xff1a;直接组合方法二&#xff1a;外观 碎碎念多个外观对象外观和封装外观和单例姑妄言之 定义 为子系统中的一组接口提供一个一致的界面&#xff0c;外观模式定义了一个高层接口&#xff0c;这…

【120版本】最新谷歌浏览器驱动下载地址

在使用selenium时可能会遇到谷歌浏览器和谷歌驱动器版本不一致的问题&#xff0c;并且国内可以搜到的谷歌浏览器下载地址里面最新的驱动器只有114版本的&#xff0c;但目前谷歌浏览器最新版本是120。所以这里记录下最新版本120谷歌驱动器下载地址&#xff1a; Chrome for Test…

Dobbo---分布式系统通信方式

通信方式 分布式系统通信方式1. RMIRMI 通信实现案例2. RPC常用RPC框架 分布式系统通信方式 1. RMI RMI ( Remote Method Invocation 远程方法调用) 图1.1 客户端-服务端通信方式 客户端将要调用的方法及参数&#xff0c;打包为辅助对象&#xff0c;通过网络socket&#xff…

【自控实验】3. 带有饱和非线性环节控制系统相平面分析

本科课程实验报告&#xff0c;有太多公式和图片了&#xff0c;干脆直接转成图片了 仅分享和记录&#xff0c;不保证全对 实验内容&#xff1a; 有无非线性环节的相轨迹对比&#xff0c;并求超调量。 在输入单位阶跃信号Xsr时&#xff0c;用示波器观察和记录系统输入饱和非线…

Hadoop-HA高可用

一、集群规划 二、HDFS高可用 官方地址 在opt目录下创建一个ha文件夹&#xff0c;将/opt/module/下的 hadoop-3.1.3拷贝到/opt/ha目录下&#xff08;记得删除data 和 log目录&#xff09; 配置core-site.xml hdfs-site.xml <configuration><!-- NameNode数据存…

个人网站制作 Part 4 添加响应式设计 | Web开发项目

文章目录 &#x1f469;‍&#x1f4bb; 基础Web开发练手项目系列&#xff1a;个人网站制作&#x1f680; 添加响应式设计&#x1f528;移动优先的响应式样式&#x1f527;步骤 1: 添加媒体查询 &#x1f528;图片和布局调整&#x1f527;步骤 2: 使用响应式图片&#x1f527;步…

如何使用网络测试仪构造特殊流量

为什么要仿真特殊流量 在现网中&#xff0c;网络流量时常伴随着突发&#xff0c;突发流量可能会造成网络的拥塞&#xff0c;从而产生丢包、抖动和时延&#xff0c;导致网络服务质量整体下降。面对宏观上的突发&#xff0c;通常采用在网络设备入向限速或者流量整形功能来消除突…

使用代理IP池实现多线程爬虫的方法

目录 前言 代理IP的概念和作用 为什么使用代理IP池 代理IP池的实现步骤 代码实现 注意事项 总结 前言 随着互联网的发展&#xff0c;爬虫技术在各个领域中被广泛应用。然而&#xff0c;目标网站对爬虫的限制也日益严格&#xff0c;例如限制单个IP的请求频率。为了解决这…

从0到1:如何建立一个大规模多语言代码生成预训练模型

国产AI辅助编程工具 CodeGeeX 是一个使用AI大模型为基座的辅助编程工具&#xff0c;帮助开发人员更快的编写代码。可以自动完成整个函数的编写&#xff0c;只需要根据注释或Tab按键即可。它已经在Java、JavaScript和Python等二十多种语言上进行了训练&#xff0c;并基于大量公开…