0


mysql signed unsigned zerofill详解

灵感来源

在这里插入图片描述

mysql

中有符号

signed

,无符号

unsigned

与零填充

zerofill

UNSIGNED

无符号

UNSIGNED

是一个属性,你可以在创建或修改表时为整数类型的列指定它。无符号属性意味着该列只能存储非负整数(

0

和正整数),而不是默认的有符号整数,后者可以存储负数、零和正数。

例如,如果你定义一个列为

INT UNSIGNED

,那么这个列就不能存储负数。相比之下,一个普通的

INT

类型的列(默认是有符号的)可以存储从

-2147483648

2147483647

的整数。而

INT UNSIGNED

类型的列可以存储从

0 到 4294967295

的整数。

使用无符号类型的好处是它可以扩大正数的存储范围,因为它不需要为负数分配空间。这在某些情况下非常有用,比如当你知道数据永远不会是负数时(例如年龄、计数器或其他只能是正的度量)。

下面是一个创建无符号列的例子:

CREATETABLE person (
    id INTUNSIGNEDAUTO_INCREMENTPRIMARYKEY,
    age TINYINTUNSIGNEDNOTNULL);

在这个例子中,

id

列是一个无符号整数,并且是自动递增的主键。

age

列是一个无符号的

TINYINT

,意味着它只能存储从

0

255

的整数。如果尝试插入一个负数到无符号列中,

MySQL

会产生一个错误或将负数转换为最接近的有效值(通常是

0

)。
类型大小无符号范围有符号范围TINYINT1 字节(-128,127)(0,255) 小整数值SMALLINT2 字节(-32 768,32 767)(0,65 535) 大整数值MEDIUMINT3 字节(-8 388 608,8 388 607)(0,16 777 215) 大整数值INT或INTEGER4 字节(-2 147 483 648,2 147 483 647)(0,4 294 967 295) 大整数值

zerofill

当插入

mysql

中该字段的值的长度小于定义的长度时,会在数值前面补全相应数据的

0

比较常用的应该是月份或日期前补

0

,还是整形数字不是字符串。

CREATETABLE`t1`(`year`year(4)DEFAULTNULL,`month`int(2)unsigned zerofill DEFAULTNULL,`day`int(2)unsigned zerofill DEFAULTNULL)ENGINE=InnoDBDEFAULTCHARSET=utf8;```
标签: mysql 数据库 java

本文转载自: https://blog.csdn.net/zhengzhaoyang122/article/details/140229920
版权归原作者 程序猿进阶 所有, 如有侵权,请联系我们删除。

“mysql signed unsigned zerofill详解”的评论:

还没有评论