mysql中int(m),varchar(m),char(m)的区别
一、int(m)
当输入值大于m时,m值无效,字段展示长度等于字符长度;
当输入值小于等于m时,如果没有搭配zerofill函数,则m值无效,字段展示长度等于字符长度;
当输入值小于等于m且搭配了zerofill函数时,展示长度为m,有缺失的位置会用0从左进行补充;
m默认为11,无论m为多少,存储空间都为4个字节。
二、char(m)和varchar(m)的区别
1、存储空间上
char为固定长度字符串,存储空间为m个字节,其中1<=m<=255
varchar为可变长度字符串,存储空间L+1个字节,其中L<=m,1<=m<=255
2、展示上
char会将保存值后的空格全部截取掉,varchar则会保留。
3、效率上
char类型每次修改数据类型的长度相同,效率更高
varchar类型每次修改数据类型的长度不同,效率更低
4、使用场景
当字段长度固定时,可以使用char类型以提高效率,如身份证号码(固定18号)等字段。
当字段长度不固定时,可以使用varchar类型,兼容性更强。