mysql signed unsigned zerofill详解

2024-07-11 1529阅读

灵感来源

mysql signed unsigned zerofill详解

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

UNSIGNED

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

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

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

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

CREATE TABLE person (
    id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
    age TINYINT UNSIGNED NOT NULL
);

在这个例子中,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,还是整形数字不是字符串。

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;```
VPS购买请点击我

免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!

目录[+]