MySQL学习

来源:互联网 发布:mysql and 编辑:程序博客网 时间:2024/06/03 12:29

char、varchar的区别

  • char(M)类型的数据列里,每个值都占用M个字节,如果某个长度小于M,MySQL就会在它的右边用空格字符补足.(在检索操作中那些填补出来的空格字符将被去掉)
  • varchar(M)类型的数据列里,每个值只占用刚好够用的字节再加上一个用来记录其长度的字节(即总长度为L+1字节).

由于某种原因char 固定长度,所以在处理速度上要比varchar快速很多,但是对费存储空间,所以对存储不大,但在速度上有要求的可以使用char类型,反之可以用varchar类型来实例。

在MySQL中用来判断是否需要进行对据列类型转换的规则

  • 在一个数据表里,如果每一个数据列的长度都是固定的,那么每一个数据行的长度也将是固定的.
  • 只要数据表里有一个数据列的长度的可变的,那么各数据行的长度都是可变的.
  • 如果某个数据表里的数据行的长度是可变的,那么,为了节约存储空间,MySQL会把这个数据表里的固定长度类型的数据列转换为相应的可变长度类型.
  • 例外:长度小于4个字符的char数据列不会被转换为varchar类型

char的用处

一,存储很短的信息,比如门牌号码101,201……这样很短的信息应该用char,因为varchar还要占个byte用于存储信息长度,本来打算节约存储的现在得不偿失。

二,固定长度的。比如使用uuid作为主键,那用char应该更合适。因为他固定长度,varchar动态根据长度的特性就消失了,而且还要占个长度信息。

三,十分频繁改变的column。因为varchar每次存储都要有额外的计算,得到长度等工作,如果一个非常频繁改变的,那就要有很多的精力用于计算,而这些对于char来说是不需要的。

Alert语句的一些小细节

用修改表结构的方式创建索引。
ALTER mytable ADD UNIQUE [indexName] ON (username(length)) ;
ALTER TABLE testalter_tbl ADD i INT;
前者直接是alert + 表名,后者是alert + table + 表名