db2 varchar最大长度_MySQL char和varchar的区别

MySQL存储字符串可以有char, varchar和text三种类型. 而text一般都是用来存储大文本(如商品的描述)数据. 但是char 和 varchar存储string字符串时有何区别呢?


  • char(n)中的n是字符数, 范围是0~255(额外需要1到2个字节来存长度)
  • varchar(n)中的n也是字符数,但是最大值需要通过编码来算, 不能超过65535字节(从中还需要拿出1到2个字节来存长度)

一般定长的数据选用char类型, 比如身份证号, 手机号, 电话等. 长度变化很大的可以使用varchar类型


经测试, 100万条的数据, char和varchar的数据类型, 无论是否添加索引, varchar的搜索都要更快一点

d3bd0656986ebad76257ef607a9349fb.png

数据条数为100万+

然后分别根据表中的两个字段进行查询

3bae1e41b96ec52a5f9444c48c34cd6f.png

根据char类型字段进行搜索

64415dd1860fe267280c445ef6af1728.png

根据varchar类型字段进行搜索

MySQL相关文章推荐:

MySql 解析顺序MySQL事务隔离级别MySQL日志(错误日志, 二进制日志, 慢查询日志等)介绍MySQL的多版本并发控制(MVCC)MySQL 索引(单列索引, 组合索引, 全文索引)及索引失效MySQL索引数据结构MySQL char和varchar的区别MySQL主从复制的过程及原理MySQL优化
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值