【MYSQL】字符串存储类型该怎么选:mysql中char、varchar、text的区别

文章目录

  • [一. 简述](#一. 简述)
  • [二. 各自特点](#二. 各自特点)

参考官网:mysql-string-type-syntax

一. 简述

  1. char长度固定: 即每条数据占用等长字节空间;适合用在身份证号码、手机号码等定。
  2. varchar可变长度:可以设置最大长度;适合用在长度可变的属性。
  3. text不设置长度: 当不知道属性的最大长度时,适合用text。

二. 各自特点

char

  • char(n)中的n表示字符数,最大长度是255个字符;
  • 如果是utf8编码方式, 那么char类型占255 * 3个字节。(utf8下一个字符占用1至3个字节)

varchar:

  • varchar(n)中的n表示字符数,最大空间是65535个字节, 存放字符数量跟字符集有关系;
  • varchar实际范围是65532或65533, 因为内容头部会占用1或2个字节保存该字符串的长度;如果字段default null(即默认值为空),整条记录还需要1个字节保存默认值null。
  • 如果是utf8编码, 那么varchar最多存65532/3 = 21844个字符。

text:

  • 跟varchar基本相同,理论上最多保存65535个字符,实际上text占用内存空间最大也是65535个字节;
  • 考虑到字符编码方式, 一个字符占用多个字节, text并不能存放那么多字符;
  • 跟varchar的区别是text需要2个字节空间记录字段的总字节数。

最后

查询速度: char最快, varchar次之,text最慢,所以 能用varchar的时候就不用text。

相关推荐
TechWayfarer9 分钟前
IP精准定位服务在保险行业的接入实践:区域需求洞察与精准服务
数据库·python·tcp/ip·flask
KKKlucifer9 分钟前
数据分类分级产品排名解析:场景定制、规则联动、增量更新成核心能力
大数据·数据库·人工智能
minji...10 分钟前
MySQL数据库 (七) MySQL表的基本查询(上),insert、replace、select、where、order by
数据库·mysql·select·replace·insert·order by·where
金融RPA机器人丨实在智能16 分钟前
数据库运维Agent比价指南:国产自研产品适配国产数据库兼容性更好吗?
运维·数据库·人工智能·ai
IT策士17 分钟前
Redis 从入门到精通:持久化RDB 与 AOF
数据库·redis·缓存
gerrywhu1 小时前
【应用实践】PostGIS实现NDVI计算与植被覆盖分级统计分析-以武汉市2025年为例
数据库·postgis·栅格数据分析·st_mapalgebra·ndvi计算·植被覆盖分级统计·植被覆盖计算
QiLinkOS1 小时前
极客与商业思维的融合实践(1)
c语言·数据库·c++·人工智能·算法·开源协议
杉氧1 小时前
Kotlin 协程深度解析④:架构实战——在 MVVM/MVI 中的进阶应用
android·kotlin
Ab_stupid1 小时前
CTF-Android培训笔记
android·笔记
chushiyunen1 小时前
高斯数据库笔记、gaussDb
数据库·笔记