精选了几道MySQL的大厂面试题,被提问的几率很高!

article/2025/8/11 19:53:30

在这里插入图片描述

🎥 作者简介: CSDN\阿里云\腾讯云\华为云开发社区优质创作者,专注分享大数据、Python、数据库、人工智能等领域的优质内容
🌸个人主页: 长风清留杨的博客
🍃形式准则: 无论成就大小,都保持一颗谦逊的心,尊重他人,虚心学习。
推荐专栏: Python入门到入魔,Mysql入门到入魔,Python入门基础大全,Flink入门到实战
🍂若缘分至此,无法再续相逢,愿你朝朝暮暮,皆有安好,晨曦微露道早安,日中炽热说午安,星河长明寄晚安🍂

MySQL面试题:如何存储IP地址?

面试官提出的问题

在MySQL中,IP地址的存储是一个常见的问题。请问你有哪些方法可以存储IP地址?并请详细解释每种方法的优缺点

问题的重点

  1. 了解IP地址的存储方法。
  2. 掌握不同存储方法的优缺点。
  3. 能够设计合理的表结构和编写相应的SQL代码。

面试者如何回答

在MySQL中,存储IP地址通常有几种常见的方法,每种方法都有其特定的应用场景和优缺点。

方法一:使用VARCHAR类型存储

最直接的方法是将IP地址作为字符串存储。IPv4地址通常用点分十进制表示,如"192.168.1.1",可以用VARCHAR(15)来存储,因为最长的IPv4地址(带掩码)也不会超过15个字符。对于IPv6地址,考虑到其长度(最多可达39个字符),可能需要VARCHAR(45)或更长。

  • 优点:
    简单直观,易于理解和查询。
  • 缺点:
    占用存储空间较大,尤其是IPv6地址。
-- 创建表结构
CREATE TABLE IPAddress (id INT AUTO_INCREMENT PRIMARY KEY,ip_address VARCHAR(45) NOT NULL
);-- 插入IPv4地址
INSERT INTO IPAddress (ip_address) VALUES ('192.168.1.1');-- 插入IPv6地址
INSERT INTO IPAddress (ip_address) VALUES ('2001:0db8:85a3:0000:0000:8a2e:0370:7334');-- 查询IP地址
SELECT * FROM IPAddress WHERE ip_address = '192.168.1.1';
  • 插入的IPv4和IPv6地址将分别存储在ip_address字段中。
  • 查询时可以直接通过字符串比较来查找对应的IP地址。

方法二:使用INT类型存储IPv4

IPv4地址可以转换为32位整数(即4字节)进行存储。这需要使用UNSIGNED INT类型,因为IPv4地址范围从0到4294967295。

  • 优点:
    节省存储空间,查询效率高。
  • 缺点:
    需要在存储和检索时进行地址与数值之间的转换,不适用于IPv6。
-- 创建表结构
CREATE TABLE IPAddress (id INT AUTO_INCREMENT PRIMARY KEY,ip_int INT UNSIGNED NOT NULL
);-- 插入IPv4地址(转换为整数)
SET @ipv4 = '192.168.1.1';
SET @ip_int = INET_ATON(@ipv4);
INSERT INTO IPAddress (ip_int) VALUES (@ip_int);-- 查询IPv4地址(将整数转换回地址)
SELECT INET_NTOA(ip_int) AS ip_address FROM IPAddress WHERE ip_int = INET_ATON('192.168.1.1');
  • INET_ATON函数用于将IPv4地址转换为整数。
  • INET_NTOA函数用于将整数转换回IPv4地址。
  • 插入的IPv4地址将被转换为整数并存储在ip_int字段中。
  • 查询时,整数将被转换回IPv4地址格式。

方法三:使用BINARY(16)或VARBINARY(16)存储IPv6

IPv6地址由128位组成,可以存储为16字节的二进制数据。INET6_ATON和INET6_NTOA函数可用于在IPv6地址的文本表示和二进制形式之间转换。

  • 优点:
    适用于IPv6地址,节省存储空间。
  • 缺点:
    需要在存储和检索时进行地址与二进制数据之间的转换。
-- 创建表结构
CREATE TABLE IPAddress (id INT AUTO_INCREMENT PRIMARY KEY,ip_ipv6 BINARY(16) NOT NULL
);-- 插入IPv6地址(转换为二进制)
SET @ipv6 = '2001:0db8:85a3:0000:0000:8a2e:0370:7334';
SET @ip6_bin = INET6_ATON(@ipv6);
INSERT INTO IPAddress (ip_ipv6) VALUES (@ip6_bin);-- 查询IPv6地址(将二进制转换回地址)
SELECT INET6_NTOA(ip_ipv6) AS ip_address FROM IPAddress WHERE ip_ipv6 = INET6_ATON('2001:0db8:85a3:0000:0000:8a2e:0370:7334');
  • INET6_ATON函数用于将IPv6地址转换为二进制数据。
  • INET6_NTOA函数用于将二进制数据转换回IPv6地址。
  • 插入的IPv6地址将被转换为二进制数据并存储在ip_ipv6字段中。
  • 查询时,二进制数据将被转换回IPv6地址格式。

总结

在MySQL中存储IP地址时,可以根据具体需求选择合适的存储方法。如果需要同时存储IPv4和IPv6地址,可以考虑使用VARCHAR类型或者分别使用INT和BINARY(16)类型,并设计合理的表结构来支持这两种地址格式。通过合理的选择和转换,可以有效地存储和管理IP地址,提高存储效率和查询性能。

MySQL面试题:长文本如何存储?

面试官提出的问题

在MySQL中,我们经常需要存储大量的文本数据,比如文章的内容、评论、日志等。请问你有哪些方法可以存储长文本?

问题的重点

  1. 了解MySQL中存储长文本的不同方法。
  2. 掌握各种存储方法的适用场景和优缺点。
  3. 能够设计合理的表结构和编写相应的SQL代码来存储和检索长文本。

面试者如何回答

在MySQL中,存储长文本数据有多种方法,每种方法都有其特定的应用场景和优缺点。以下是详细的介绍和示例代码。

方法一:使用TEXT类型

MySQL提供了四种TEXT类型来存储长文本数据:TINYTEXT、TEXT、MEDIUMTEXT和LONGTEXT。它们分别可以存储最多255、65,535、16,777,215和4,294,967,295个字符的文本数据。

  • 优点:
    专为存储长文本设计,性能较好。
    可以直接进行全文检索(如果使用MyISAM存储引擎和全文索引)。
  • 缺点:
    对于非常大的文本数据,可能会影响数据库的性能和备份恢复速度。
    在某些情况下,可能需要额外的处理来管理大文本字段,比如分页显示或压缩存储。
-- 创建表结构,使用TEXT类型存储长文本
CREATE TABLE Articles (id INT AUTO_INCREMENT PRIMARY KEY,title VARCHAR(255) NOT NULL,content TEXT NOT NULL -- 使用TEXT类型存储文章内容
);-- 插入长文本数据
INSERT INTO Articles (title, content) VALUES ('MySQL长文本存储', '这是一篇关于MySQL如何存储长文本的文章...');-- 查询长文本数据
SELECT title, content FROM Articles WHERE id = 1;
  • CREATE TABLE语句创建了一个名为Articles的表,其中content字段使用TEXT类型来存储长文本。
  • INSERT INTO语句向表中插入了一条记录,包括文章的标题和长文本内容。
  • SELECT语句用于查询并显示指定ID的文章的标题和内容。
  • 插入和查询操作将成功执行,并返回指定ID的文章的标题和长文本内容。

方法二:使用BLOB类型

虽然BLOB(Binary Large Object)类型主要用于存储二进制数据(如图片、音频、视频等),但它也可以用来存储长文本数据,特别是当文本数据包含大量非ASCII字符(如UTF-8编码的多语言文本)时。

  • 优点:
    可以存储任意类型的二进制数据,包括长文本。
    对于包含大量非ASCII字符的文本数据,可能比TEXT类型更节省存储空间。
  • 缺点:
    不适合直接进行文本检索和排序操作。
    可能会增加数据库的复杂性和管理难度。
    注意:在实际应用中,通常更倾向于使用TEXT类型来存储长文本数据,除非有特定的理由需要使用BLOB类型(如存储二进制数据或需要更高效的非ASCII字符存储)。

方法三:使用外部存储

对于非常大的文本数据(如大型日志文件、电子书等),可以考虑将文本数据存储在数据库外部的文件系统中,并在数据库中存储文件的路径或URL。

  • 优点:
    减轻数据库的负担,提高性能和可扩展性。
    便于对文件进行直接访问和处理(如压缩、解压缩、分割等)。
  • 缺点:
    需要额外的文件系统管理操作。
    可能需要处理文件路径或URL的安全性和访问权限问题。
-- 创建表结构,使用VARCHAR类型存储文件路径
CREATE TABLE LargeTexts (id INT AUTO_INCREMENT PRIMARY KEY,title VARCHAR(255) NOT NULL,file_path VARCHAR(255) NOT NULL -- 存储文件路径或URL
);-- 插入文件路径数据
INSERT INTO LargeTexts (title, file_path) VALUES ('大型日志文件', '/path/to/large/logfile.txt');-- 查询文件路径数据
SELECT title, file_path FROM LargeTexts WHERE id = 1;
  • CREATE TABLE语句创建了一个名为LargeTexts的表,其中file_path字段使用VARCHAR类型来存储文件的路径或URL。
  • INSERT INTO语句向表中插入了一条记录,包括文本的标题和文件路径。
  • SELECT语句用于查询并显示指定ID的文本的标题和文件路径。
  • 插入和查询操作将成功执行,并返回指定ID的文本的标题和文件路径。然后,可以通过文件系统访问和处理对应的文本文件。

总结

在MySQL中存储长文本数据时,可以根据具体需求选择合适的存储方法。对于大多数长文本应用场景,TEXT类型是一个很好的选择,因为它专为存储长文本设计,并且性能较好。如果文本数据非常大或者包含大量非ASCII字符,可以考虑使用BLOB类型或外部存储方法。在选择存储方法时,需要权衡各种因素的优缺点,包括性能、存储空间、管理复杂性等。


http://www.hkcw.cn/article/bfxhyNimAI.shtml

相关文章

搞定mysql的 行转列(7种方法) 和 列转行

一、行转列 1、使用case…when…then 2、使用SUM(IF()) 生成列 3、使用SUM(IF()) 生成列 WITH ROLLUP 生成汇总行 4、使用SUM(IF()) 生成列,直接生成汇总结果,不再利用子查询 5、使用SUM(IF()) 生成列 UNION 生成汇总行,并利用 IFNULL将汇总行标题…

高并发场景下的热点key问题探析与应对策略

目录 一、问题描述 二、发现机制 三、解决策略分析 (一)解决策略一:多级缓存策略 客户端本地缓存 代理节点本地缓存 (二)解决策略二:多副本策略 (三)解决策略三:热点…

SQL Server——SSMS中数据库、表的创建

目录 一、引言 二、数据库、表的创建与删除 (一)方法一:在SSMS控制平台上进行创建 (二)方法二:使用 SQL 代码实现对数据库和表的创建 三、SQL 和 T-SQL 一、引言 在学习数据库的过程中,初…

spring AOP详解

文章目录 AOP1 环境准备1.1 工程及接口创建1.2 工程存在的问题1.2.1 问题1.2.2 解决思路 2 AOP面向切面编程2.1 AOP概述2.2 AOP原理分析 3 基于注解的AOP3.1 入门示例3.2 使用流程3.3 切入点表达式3.4 练习3.5 通知类型 AOP ​ AOP(Aspect Orient Programming&…

重看Spring聚焦ApplicationContext分析

目录 一、理解下ApplicationContext的设计 (一)功能性的理解 (二)ApplicationContext 结构类图 二、ApplicationContext根接口 (一)源码展示 (二)分析说明 三、子接口Configu…

【MySQL安装】—报错“Can‘t connect to local MySQL server through socket ‘varlibmysqlmysql.sock‘”

项目场景: 执行 “mysql -uroot -p” 命令,进入MySQL数据库。 问题描述: 报错: Cant connect to local MySQL server through socket /var/lib/mysql/mysql.sock 原因分析: /var/lib/mysql路径下缺少mysql.sock文件。 …

本地部署Vanna实战,快速解决NLP2SQL

一、背景 ​ 随着DeepSeek的火爆,基于AI的应用也如雨后春笋般迸发出来,如何根据用户的一句话来找到用户所需要的信息,采用传统的方式无法通过模糊匹配等实现复杂的业务场景,故探索一种新的思路来实现信息获取。Text2SQL将自然语言…

【MySQL】基础操作

MySQL(二)基础操作 一、数据库操作 1.创建库 2.查看库 3.选中库 4.删除库 二、表操作 1.创建表 1.1[comment 注释]: 1.2,...: 2.查看表 2.1查看所有表 2.2查看表结构 3.删除表 三、记录操作 1.插入记录 1.1全列插入 1.2指定列插入 1.3…

嵌入式硬件篇---蜂鸣器

蜂鸣器是一种常用的电子发声元件,主要分为有源蜂鸣器和无源蜂鸣器两类。它们在结构、工作原理、驱动方式、应用场景等方面存在显著差异。以下是详细介绍: 一、核心定义与结构差异 1. 有源蜂鸣器 定义: “有源” 指内部自带振荡电路&#x…

工程的焊接技术

一、焊接设备与材料 焊接设备:对应不同焊接方法,如焊条电弧焊设备包括电焊机、焊钳、接地夹等。 焊接材料 焊条 分类:按熔渣性质分为碱性焊条(低氢型)和酸性焊条。 选用原则:根据焊接场景选择,…

HackMyVM-Teacher

信息搜集 主机发现 ┌──(kali㉿kali)-[~] └─$ nmap -sn 192.168.43.0/24 Starting Nmap 7.95 ( https://nmap.org ) at 2025-06-01 01:02 EDT Nmap scan report for 192.168.43.1 Host is up (0.0084s latency). MAC Address: C6:45:66:05:91:88 (Unknow…

AE矩形工具蒙版找不到椭圆形工具怎么办?

是不是也跟我一样遇到了这个问题 ? 还以为是自己安装的版本有问题。其实并没有。 只需要选择矩形工具,鼠标左键,长按1s即可有其他选项 这样就解决啦

Linux 学习-模拟实现【简易版bash】

1、bash本质 在模拟实现前,先得了解 bash 的本质 bash 也是一个进程,并且是不断运行中的进程 证明:常显示的命令输入提示符就是 bash 不断打印输出的结果 输入指令后,bash 会创建子进程,并进行程序替换 证明&#x…

【Android SDK(adb命令环境)工具安装下载教程】

1、打开下载地址:SDK 平台工具版本说明 | Android Studio | Android Developers 2、下载Android SDK Platform-Tools压缩包,选择路径进行解压 3、复制SDK文件platform-tools保存的路径 4、配置adb环境变量;按下wini,在设置界面搜索”环境…

Redis可视化工具 RDM mac安装使用

第一步:https://pan.baidu.com/s/10vpdhw7YfDD7G4yZCGtqQg?at1673701651004将dmg下载 第二部:点击下载的dmg文件进行安装、mac可能会提示: 无法验证此App不包含恶意软件 解决方法: 打开系统偏好设置>安全性与隐私>通用&am…

Mac 使用 Crossover 加载 Windows Steam 游戏库,实现 Windows/Mac 共享移动硬盘

Mac 使用 Crossover 加载 Windows Steam 游戏库,实现 Windows/Mac 共享移动硬盘 1. 在Crossover上安装Steam2. Steam容器加载移动硬盘3. 配置Steam库 前言:本文介绍了如何在Crossover上安装Steam并加载外接移动硬盘,实现在Window上下载的游戏…

Mac上媲美TortoiseSVN 的Svn的强大客户端 — macSvn

什么是macSvn? 如果你使用过 svn 那肯定听说过 TortoiseSVN, 但是 TortoiseSVN 并不支持在 mac 上使用。而 macSvn 是一款专为macOS设计的SVN(Subversion)客户端,它和TortoiseSVN一样,提供了直观的图形化操作方式.操作非常方便! …

给Android Studio配置本地gradle和maven镜像地址,加快访问速度

Android Studio在创建工程后默认会访问Google自己的官网去下载gradle和maven依赖项,国内访问Google的速度相当慢,如果没有科学上网的话,甚至无法访问。本文记录如何解决这些问题。 配置本地gradle 下载gradle 首先需要去国内的网站下载gra…

Flutter 打包报错:Execution failed for task ‘:flutter_plugin_android_lifecycle的解决办法

本篇文章主要讲解:Flutter 打包报错:Execution failed for task :flutter_plugin_android_lifecycle的解决办法。 日期:2025年2月16日 作者:任聪聪 报错现象: 报文信息: FAILURE:Buildfailedwithexception…

uniapp从入门到精通(全网保姆式教程)~ 别再说你不会开发小程序了

目录 一、介绍 二、环境搭建(hello world) 2.1 下载HBuilderX 2.2 下载微信开发者工具 2.3 创建uniapp项目 2.4 在浏览器运行 2.5 在微信开发者工具运行 2.6 在手机上运行 三、项目基本目录结构 四、开发规范概述 五、全局配置文件&#xff0…