【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。

相关推荐
李慕婉学姐2 分钟前
Springboot传统文化服饰交流平台k79z52ic(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库·spring boot·后端
Predestination王瀞潞15 分钟前
映射文件中的四大核心 CRUD 操作标签(对应数据库的增、删、改、查操作)
数据库·oracle
IvorySQL19 分钟前
PostgreSQL 技术日报 (3 月 12 日)|为什么加索引反而变慢?这招让查询快 50 倍
数据库·postgresql·开源
y = xⁿ20 分钟前
【从零开始学习Redis|第五篇】Redis 常见数据类型和应用场景
数据库·redis·学习·缓存
kuntli40 分钟前
索引失效的五大关键场景
mysql
DolphinDB智臾科技44 分钟前
DolphinDB:技术赋能钢铁业,国产时序数据库领路数智化落地
数据库·物联网·时序数据库·dolphindb
熬夜有啥好44 分钟前
Linux软件编程——数据库——自制小词典
数据库·linux软件编程·自制词典
青桔柠薯片1 小时前
数据库编程:从SQLite基础到C语言集成
linux·数据库·学习·sqlite
技术净胜1 小时前
MySQL 主从复制(日志核心)完整教程
数据库·mysql·adb