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

相关推荐
美狐美颜SDK开放平台4 分钟前
跨平台开发实战:直播美颜sdk动态贴纸在 Android / iOS / HarmonyOS 的落地方案
android·ios·harmonyos·美颜sdk·直播美颜sdk·视频美颜sdk·美颜api
2501_916008894 分钟前
在不越狱前提下导出 iOS 应用文件的过程,访问应用沙盒目录,获取真实数据
android·macos·ios·小程序·uni-app·cocoa·iphone
枷锁—sha4 分钟前
【PortSwigger Academy】SQLi UNION 攻击 (确定列数)
服务器·数据库·学习·安全·网络安全
qq_366086226 分钟前
sql server多字段字符串模糊查询存在字段null值查询失效问题
数据库
2501_915106326 分钟前
Android和IOS 移动应用App图标生成与使用 Assets.car生成
android·ios·小程序·https·uni-app·iphone·webview
无籽西瓜a8 分钟前
详解Redis持久化:RDB、AOF与混合持久化
数据库·redis·缓存
人工智能知识库9 分钟前
华为HCCDA-GaussDB题库(带详细解析)
数据库·华为·gaussdb·题库·hccda-gaussdb·hccda
齐 飞10 分钟前
数据库批量插入耗时过长问题rewriteBatchedStatements=true
数据库·mysql
sg_knight10 分钟前
SQL 中的 IFNULL 函数是什么?
数据库·sql·mysql·oracle·database·关系型数据库·db
灵感菇_11 分钟前
深入解析 Android事件分发机制
android·ui