mysql面试题 Day1

目录

1 可以使用mysql直接存储文件吗?

2 什么时候存文件,什么时候不存文件?

3 存储文件,有遇到什么问题吗?

4 emoji 乱码怎么办?

5 如何存储ip地址?


1 可以使用mysql直接存储文件吗?

在MySQL中存储文件通常指的是将文件作为BLOB数据存入数据库中。

BLOB (binary large object):二进制大对象的字段类型 ,主要用于存储二进制大对象,例如可以存储图片,音视频等文件。

按照存储容量来分类,blob 类型可分为以下四种:

类型    存储大小 用途
TINYBLOB  0 - 255字节短文本二进制字符串
BLOB 0 - 65KB二进制形式的字符串
MEDIUMBLOB0 - 16MB二进制形式的长文本数据
LONGBLOB0 - 4GB 二进制形式的极大文本数据


其中最常用的就是 blob 字段类型了,最多可存储 65KB 大小的数据,一般可用于存储图标或 logo 图片。不过数据库并不适合直接存储图片,如果有大量存储图片的需求,请使用对象存储或文件存储,数据库中可以存储图片路径来调用。

2 什么时候存文件,什么时候不存文件?

存:

  1. 小型文件和少量文件

    MySQL 可以存储小型文件,比如少于几兆字节的文件,而不会显著增加数据库的负担。

不存:

  1. 大型文件和大量文件

    MySQL 并不适合存储大型文件(比如几十兆字节以上)或者大量的文件,因为这样会显著增加数据库的存储和管理负担,降低数据库的性能。
  2. 文件频繁更新

    如果文件需要频繁更新或替换,存储在数据库中会导致数据库的性能瓶颈,因为每次更新都会导致整个文件数据的写入和数据库的日志记录。
  3. 需要外部访问和处理

    如果文件需要由外部程序直接访问或处理,将文件存储在数据库中可能会增加额外的复杂性和开销,不如直接存储文件路径来得简单和高效。
  4. 存储要求高

    数据库系统的存储空间有限,如果存储大量文件可能会超出数据库的存储能力,不如使用专门的文件系统或对象存储服务来存储文件。

3 存储文件,有遇到什么问题吗?

  1. 文件大小超过限制

    • 解释:MySQL有内置的文件大小限制,例如max_allowed_packet

    • 解决方法:调整my.cnfmy.ini配置文件中相关参数的值,以支持更大的文件。

  2. 权限问题

    • 解释:MySQL进程没有足够的权限去写入文件到指定目录。

    • 解决方法:修改文件目录权限,确保MySQL进程可以读写该目录。

4 emoji 乱码怎么办?

使用utf8mb4

MySQL在5.5.3之后增加了这个utf8mb4的编码,mb4就是most bytes 4的意思,专门用来兼容四字节的unicode。好在utf8mb4是utf8的超集,除了将编码改为utf8mb4外不需要做其他转换。当然,一般情况下使用utf8也就够了。

5 如何存储ip地址?

  1. 使用字符串

  2. 使用无符号整型

使用字符串注意:

  • 如果你需要支持IPv6地址,那么最长可能是39个字符,因此可以考虑使用 VARCHAR(39)

使用无符号整型注意:

  • 支持范围查询

  • ipv4 使用 INET_ATON()INET_NTOA() 

  • ipv6 使用 INET6_ATON()INET6_NTOA()

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

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

相关文章

Web的UI自动化基础知识

目录 1 Web自动化入门基础1.1 自动化知识以及工具1.2 主流web自动化测试工具1.3 入门案例 2 使用工具的API2.1 元素定位2.1.1 id选择器2.1.2 name2.1.3 class_name选择器2.1.4 tag_name选择器2.1.5 link_text选择器2.1.6 partial_link_text选择器2.1.7 xpath选择器2.1.8 CSS选择…

华子 Ascend C算子开发能力认证考试(初级)微认证考试答案(直接Ctrl + F搜关键词就可以了)

根据提供的文件内容,这里是一系列关于Ascend C编程的多选题: **第21题**: 题目:Ascend C的矢量编程范式把算子实现流程分为哪些基本任务。 选项: A. Compute B. CopyIn C. CopyOut D. Aggregate E. Split 正确答案&a…

Docker在容器启动时自动执行特定脚本

在Dockerfile中使用CMD或ENTRYPOINT执行脚本,以实现容器启动时执行特定脚本的目的。 示例Dockerfile: FROM ubuntu:20.04# 复制脚本到容器中 COPY start.sh /usr/local/bin/start.sh# 确保脚本具有可执行权限 RUN chmod x /usr/local/bin/start.sh# 使…

mediamtx流媒体服务器测试

MediaMTX简介 在web页面中直接播放rtsp视频流,重点推荐:mediamtx,不仅仅是rtsp-CSDN博客 mediamtx github MediaMTX(以前的rtsp-simple-server)是一个现成的和零依赖的实时媒体服务器和媒体代理,允许发布,读取&…

HTML列表指南:有序、无序与自定义列表的妙用

在网页设计中,列表是组织和展示信息的有效方式,它帮助读者更好地理解和记忆内容结构。HTML提供了三种类型的列表:有序列表、无序列表和自定义列表,每种都有其独特的应用场景。下面,我们将逐一探索这三种列表的使用方法…

mysql的索引可以分为哪些类型

MySQL的索引是用于提高查询性能的重要数据结构。不同类型的索引在不同的使用场景中具有不同的优势和适用性。 1. 主键索引(Primary Key Index) 特点:唯一且不允许 NULL 值。用途:唯一标识表中的每一行。自动创建:定义…

Azure OpenAI 服务

Azure OpenAI 服务 一、什么是生成式 AI二、Azure OpenAI 服务三、Azure OpenAI 与 Azure AI 服务的关系四、如何使用 Azure OpenAI1、这些 OpenAI 模型分为几个主要系列:五、负责任的 AI 策略1、Azure OpenAI 的使用应遵循六项 Microsoft Al原则:用户可通过 Azure OpenAI 服…

牛客周赛 Round 46:祥子拆团(组合数学,计数问题)

题目描述 Sakiko有两个数字 x,yx,yx,y ,她想知道,有多少种方式可以将 xxx 拆成 yyy 个正整数的乘积。 例如 x6,y2x6,y2x6,y2 时,有 616,326,236,1666 \times 16,3 \times 26,2 \times 36,1 \times 66616,326,236,166 这 4 种方法。 由于这个…

React性能优化分享

本篇将介绍在React编码过程中需要注意的性能优化点。鉴于图片懒加载、虚拟滚动列表等已成为广为人知的通用性能优化手段,本文将不再赘述这些内容。 memo memo允许组件在 props 没有改变的情况下跳过重新渲染 默认通过Object.is比较每个prop,可通过第二个…

可视化大屏开发系列——页面布局

页面布局是可视化大屏的基础,想要拥有一个基本美观的大屏,就得考虑页面整体模块的宽高自适应,我们自然就会想到具有强大灵活性flex布局,再借助百分比布局来辅助。至此,大屏页面布局问题即可得到解决。 写在前面&#x…

哪些数据管理知识领域需要做到数据全生命周期管理

一、数据生命周期 数据管理、数据治理、数据安全、元数据管理、数据治理等知识领域,都需要按照数据的生命周期开展管理工作。数据生命周期包括计划、设计/启用、创建/获取、存储/维护、使用、增强和处置。详见下图。 1.数据治理生命周期 1)规划:将数据要求与业务战略连接起…

PTA 6 - 20 汉诺塔问题(py 递归)

这道题是一道比较典型的递归问题,他跟斐波那契数列的本质是一样的,大家自己动手推理一下,非常好推 参考代码: def hanoi(n,a,b,c):global stepif n 1:print(a,"->",c)step 1else:hanoi(n-1,a,c,b)print(a,"…

查看npm版本异常,更新nvm版本解决问题

首先说说遇见的问题,基本上把nvm,npm的坑都排了一遍 nvm版本导致npm install报错 Unexpected token ‘.‘install和查看node版本都正确,结果查看npm版本时候报错 首先就是降低node版本… 可以说基本没用,如果要降低版本的话&…

用python纯手写一个日历

一、代码 # 月份名称数组 months ["January", "February", "March", "April", "May", "June","July", "August", "September", "October", "November", &qu…

深度解析RocketMq源码-持久化组件(二) MappedFileQueue

1.绪论 MappedFileQueue是commitLog中最核心的主组件。前面讲解commitLog的时候也曾说过,MappedFileQueue本质上就是一个MappedFile队列,而commitLog操纵Mmapped读写的时候,也是通过MappedFileQueue来实现的。 commitlog和mappedfilequeue和…

git下载路径

第一步 1进入官网:Git - Downloading Package 第二步 根据自己的系统选择对应版本下载

局域网内怎么访问另一台电脑?(2种方法)

案例:需要在局域网内远程电脑 “当我使用笔记本电脑时,有时需要获取保存在台式机上的文件,而两者都连接在同一个局域网上。我的台式机使用的是Windows 10企业版,而笔记本电脑则是Windows 10专业版。我想知道是否可以通过网络远程…

springboot-自定义配置

在springboot项目中,最常用的自定义配置就是,在yml文件中,添加一些配置,然后,通过springboot的集成功能,赋值某个bean。 在yml文件中新建我们需要的配置信息,如下: user:id: 2user…

OpenCV计算形状之间的相似度ShapeContextDistanceExtractor类的使用

操作系统:ubuntu22.04OpenCV版本:OpenCV4.9IDE:Visual Studio Code编程语言:C11 1.功能描述 ShapeContextDistanceExtractor是OpenCV库中的一个类,主要用于计算形状之间的相似度或距离。它是基于形状上下文(Shape Co…

26.1 WEB框架介绍

1. Web应用程序 1.1 应用程序有两种模式 应用程序的架构模式主要分为两种: C/S (客户端/服务器端)和B/S(浏览器/服务器端). * 1. C/S模式, 即客户端/服务器模式(Client/Server Model): 是一种分布式计算模式.它将应用程序的功能划分为客户端和服务器端两部分.在这种模式下, 客…