当前位置: 代码网 > it编程>数据库>Mysql > mysql signed unsigned和zerofill使用与区别

mysql signed unsigned和zerofill使用与区别

2024年07月21日 Mysql 我要评论
灵感来源mysql中有符号signed,无符号unsigned与零填充zerofillunsigned无符号unsigned是一个属性,你可以在创建或修改表时为整数类型的列指定它。无符号属性意味着该列

灵感来源

在这里插入图片描述

mysql中有符号signed,无符号unsigned与零填充zerofill

unsigned

无符号unsigned是一个属性,你可以在创建或修改表时为整数类型的列指定它。无符号属性意味着该列只能存储非负整数(0和正整数),而不是默认的有符号整数,后者可以存储负数、零和正数。

例如,如果你定义一个列为int unsigned,那么这个列就不能存储负数。相比之下,一个普通的int类型的列(默认是有符号的)可以存储从-21474836482147483647的整数。而int unsigned类型的列可以存储从0 到 4294967295的整数。

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

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

create table person (
    id int unsigned auto_increment primary key,
    age tinyint unsigned not null
);

在这个例子中,id列是一个无符号整数,并且是自动递增的主键。age列是一个无符号的tinyint,意味着它只能存储从0255的整数。如果尝试插入一个负数到无符号列中,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,还是整形数字不是字符串。

create table `t1` (  
  `year` year(4) default null,  
  `month` int(2) unsigned zerofill default null,  
  `day` int(2) unsigned zerofill default null  
) engine=innodb default charset=utf8;```

到此这篇关于mysql signed unsigned和zerofill使用与区别的文章就介绍到这了,更多相关mysql signed unsigned zerofill内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网! 

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com