23、varchar与char的区别

varchar与char的区别

char的特点

  1. char表示定长字符串,长度是固定的;
  2. 如果插入数据的长度小于char的固定长度时,则用空格填充;
  3. 因为长度固定,所以存取速度要比varchar快很多,甚至能快50%,
  4. 但正因为其长度固定,所以会占据多余的空间,是空间换时间的做法;
  5. 对于char来说,最多能存放的字符个数为255,和编码无关

varchar的特点

  1. varchar表示可变长字符串,长度是可变的;
  2. 插入的数据是多长,就按照多长来存储;
  3. varchar在存取方面与char相反,它存取慢,因为长度不固定,但正因如此,不占据多余的空间,是时间换空间的做法;
  4. 对于varchar来说,最多能存放的字符个数为65532

总之,结合性能角度(char更快)和节省磁盘空间角度(varchar更小),具体情况还需具体来设计数据库才是妥当的做法

相关推荐
AI题库2 小时前
PostgreSQL 18 从新手到大师:实战指南 - 2.5 Serverless PostgreSQL
数据库·postgresql·serverless
IT技术分享社区2 小时前
数据库实战:MySQL多表更新JOIN操作的底层原理与性能调优指南
数据库·mysql·程序员
廋到被风吹走2 小时前
【数据库】【Oracle】分区表与大表设计
数据库·oracle
UrSpecial3 小时前
InnoDB存储引擎
数据库·mysql
gjc5923 小时前
MySQL隐蔽 BUG:组合条件查询无故返回空集?深度排查与规避方案
android·数据库·mysql·bug
❀͜͡傀儡师3 小时前
docker部署PostgreSQL数据库的监控和管理工具
数据库·docker·postgresql
a187927218314 小时前
MySQL 事务
数据库·mysql·事务·mvcc·acid·readview·可见性判断算法
梨落秋霜4 小时前
Python入门篇【元组】
android·数据库·python
Caarlossss4 小时前
mybatis
java·数据库·tomcat·maven·mybatis·mybatis-spring