MySQL UNSIGNED和ZEROFILL属性

  • 2019 年 10 月 11 日
  • 笔记

UNSIGNED
这个属性就是标记数字类型是无符号的,和C/C++语言中的unsigned含义是一样的,int signed的类型范围是-2147483648~2147483648,而int unsigned的范围是0~4294967295

这个属性使用时候可以在建表语句、加字段语句或者查询sql里也是可以的

create table t (a int unsigned)ENGINE=INNODB;  select cast(a as signed integer);  

ZEROFILL
这个属性的意思是,如果宽度小于设定的宽度,则自动填充0,当然只是显示而已
ZEROFILL用在字段后面就可以,可以在建表语句、加字段语句

alter table t change column a a int(4) unsigned zerofill;

例子:

  CREATE TABLE t (a INT UNSIGNED)ENGINE=INNODB;  INSERT INTO t SELECT 1;  SELECT a,HEX(a) FROM t;  ALTER TABLE t CHANGE a a INT(4) SIGNED ZEROFILL;  SELECT a,HEX(a) FROM t;  

在这里插入图片描述