快乐十分20选8技巧 www.6qljx.cn varchar和char在MySQL数据库中都是用来保存字符型数据的,但是无论从结构还是从数据的保存方式来看,两者的相差很大。

定长与变长

char 表示定长,长度固定,比如char(10),表示存储的是10个字符,无论你插入的是多少,都是10个,如果少于10个,则用空格填满。

varchar表示变长,即长度可变。varchar(10),当插入的字符小于10个的话,则插入多少个字符就存多少个。对于varchar来说,因为需要知道所存储字符的长度,需要使用一个(如果字符串长度小于255)或两个字节(长度大于255)来存储字符串的长度。

存储容量的差异

对 char 来说,最多能存放的字符个数 255,和编码无关。

varchar 字段是将实际内容单独存储在聚簇索引之外,内容开头用1到2个字节表示实际长度(长度超过255时需要2个字节),因此最大长度不能超过65535字符。

根据编码不同,长度限制也不同:

字符类型为Latin1,每个字符占用1个字节,最大长度不能超过65532;

字符类型若为gbk,每个字符最多占2个字节,最大长度不能超过32766;

字符类型若为utf8,每个字符最多占3个字节,最大长度不能超过21845。

若定义的时候超过上述限制,则varchar字段会被强行转为text类型,并产生warning。

计算方法为:

(65535-1-2)/每个字符占用的字节数= 32766 个字符。

减1的原因是实际行存储从第二个字节开始;

减2的原因是varchar头部的2个字节表示长度;

转载请注明:快乐十分20选8技巧 » MySQL中varchar与char的区别

我来说说

(便于我们更好的交流)

有不明白的地方欢迎留言哦~
取消
  • 面包屑-热门标签-华商生活 2019-04-23
  • 黄子韬的下颚线简直完美!有棱有角的!能get到黄子韬的帅吗?[色][色][色][色] 2019-04-16
  • 落实学生视力分级管理应抓好考核的“牛鼻子” 2019-04-15
  • 高清:中国男篮抵达洛杉矶 长途飞行队员略显疲惫 2019-04-14
  • 【北京奥吉通国门车型报价】北京奥吉通国门4S店车型价格 2019-04-01
  • 深改组1000天——亚心网专题 2019-03-23
  • 阳泉首次颁布地方实体性法规 两部法规将于7月1日起实施 2019-03-23
  • 人民日报客户端宣传页 2019-03-15
  • 阿不都20+5王哲林14分 红队20分大胜复仇澳联队 2019-03-15
  • 辽宁:电商成为精准扶贫的“利器” 2018-09-14
  • 鄱阳湖花海:文明仍应成为最美风景 2018-09-14
  • 时间放宽了,考核更难了 2018-07-26
  • 新时代 新作为 新篇章 2018-07-25
  • 大厨风范的海鲜做法,小白也能学会,鲜美营养,好吃到哭 2018-07-25
  • 我老张工可没有笑博士的野心,但自信有笑博士无法企及的本事。科学技术支持计划经济,在计划经济下,资源的配置和需要是计划的,无需个人去过多地操心。个人对社会,主要是 2018-07-25
  • 714| 305| 829| 139| 116| 204| 133| 819| 194| 420|