Mysql之int,char,varchar

首先我们需要知道一个字节等于8位,位就是计算机能识别的单位,即0101,对于ascii码,一个字符就是一个字节,对于gbk,两个字节是一个字符,对于utf8,三个字节是一个字符;

int(n)之n

create table text(num int(n) unsigned),那个n并不是代表存储的位数:我们来验证一下:我们在建表的时候给int 加了一个1,我们可以看到并不是只能插进去一位,所以那个n并不是位数,当我们插入的值大于了它最大能插入的值,插进去的就是它的最大值,int存储的是4个字节,也就是32位,所以最大就是2的32次方,

那么n到底起个什么作用呢?其实n只有和关键字zerofill一起的时候才会有作用,当和zerofill一起作用于字段的时候,如果插入的值的位数小于n那么就是填充零,如果大于n就不作用;所以n只有和zerofill在一起才会有作用;

char(n)之n

char(n)的n又是什么含义呢?是字节,还是字符,还是长度呢?首先我们知道char是存定长的字符,长度不够的会补空格,现在来验证一下n到底是什么:从下面可以看出我们插入了多条数据,当不足n长度的时候会填充空格,超过n会截取,我们知道在utf8编码的情况下,一个中文字符是3个字节,所以这个n肯定不是字节了,很明显这个n表示的应该是字符,其实就是长度;

这就是字节和字符的对应了;length取得是字节,char_length取得是字符;

char(n)的n其实就是字符的长度,最大可以存255个字符,

varchar(n)和char差不多,只不过varchar是变长,可以更合理的利用空间来存储数据,varchar的n也是字符长度;可以存21844个字符长度

最后在介绍一下sql_mode,sql_mode是sql插入数据的模式,主要有两种,一种是默认的宽松的插入模式ANSI,宽松的模式插入的时候如果超过长度,超过最大值就会截取,保证数据都能插进去,如果是严格的STRICT_TRANS_TABLES就会严格的比较数据,只要数据不在范围内就会报错;

默认模式下,超过范围也能插入,只不过会有警告;

严格模式下,只要超过长度就会报错;

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 与岁月无关 不用担心你的容颜会老去 就像你并不担心阳光会躲避你满是皱纹的脸 就像你也并不知道你在我心里有多美 这一...
    番茄爱吃西红柿阅读 1,020评论 0 0
  • 昨晚和一个朋友聊天聊得比较晚,后来准备进入梦乡却怎么也睡不着。这位朋友是个军人,这让我想起了很多很多... 因为是...
    cdc816ee6f6c阅读 2,669评论 0 1
  • 任务地址 https://bbs.excellence-girls.org/topic/210/ 完成时间 201...
    lavender21阅读 1,735评论 0 1
  • 有那样的人 撕裂开最真实的一面 若无其事的铺展 像对待一个离了世又无关的人 然后 告诉过路的 用铿锵的声音 说 这...
    牧小善阅读 2,350评论 0 1