mysql signed unsigned和zerofill使用与区别

 更新时间:2024年07月21日 11:49:32   作者:程序猿进阶  
mysql中有符号signed,无符号unsigned与零填充zerofill,本文主要介绍了mysql signed unsigned和zerofill使用与区别,具有一定的参考价值,感兴趣的可以了解一下

灵感来源

在这里插入图片描述

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内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家! 

相关文章

  • MySQL CHAR和VARCHAR区别

    MySQL CHAR和VARCHAR区别

    本文主要介绍了MySQL CHAR和VARCHAR区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • java连接mysql底层封装详解

    java连接mysql底层封装详解

    这篇文章主要介绍了java连接mysql底层封装,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • MySQL如何导入csv格式数据文件解决方案

    MySQL如何导入csv格式数据文件解决方案

    本文将详细介绍MySQL如何导入csv格式数据文件并提供详细解决方案,需要了解的朋友可以参考下
    2012-11-11
  • MySql Error 1698(28000)问题的解决方法

    MySql Error 1698(28000)问题的解决方法

    这篇文章主要介绍了MySql Error 1698(28000)问题的解决方法,需要的朋友可以参考下
    2017-06-06
  • MySQL的逻辑架构及工作全流程

    MySQL的逻辑架构及工作全流程

    这篇文章主要介绍了MySQL的逻辑架构及工作全流程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-03-03
  • mysql 5.7.18 winx64 免安装 配置方法

    mysql 5.7.18 winx64 免安装 配置方法

    这篇文章主要介绍了mysql 5.7.18 winx64 免安装配置方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-04-04
  • MySql索引详细介绍及正确使用方法

    MySql索引详细介绍及正确使用方法

    这篇文章主要介绍了MySql索引详细介绍及正确使用方法的相关资料,需要的朋友可以参考下
    2017-07-07
  • MySQL中关于case when的用法

    MySQL中关于case when的用法

    这篇文章主要介绍了MySQL中关于case when的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-06-06
  • 微信公众平台开发 数据库操作

    微信公众平台开发 数据库操作

    这篇文章主要介绍了微信公众平台开发 数据库操作的相关资料,需要的朋友可以参考下
    2016-10-10
  • 面试中老生常谈的MySQL问答集锦夯实基础

    面试中老生常谈的MySQL问答集锦夯实基础

    这篇文章主要为大家介绍了面试中老生常谈的MySQL问答集锦,不仅可以帮助大家顺利通过面试更可以夯实大家的基础,有需要的朋友可以借鉴参考下
    2022-03-03

最新评论