​ MySQL支持SQL标准整数类型integer(或INT)和SMALLINT。作为标准的扩展,MySQL还支持整数类型TINYINT、MEDIUMINT和BIGINT。

类型 所占字节 有符号最小值 无符号最小值 有符号最大值 无符号最大值
TINYINT 1 -128 0 127 255
SMALLINT 2 -32768 0 32767 65535
MEDIUMINT 3 -8388608 0 8388607 16777215
INT 4 -2147483648 0 2147483647 4294967295
BIGINT 8 -263 0 263-1 264-1

下面是创建表的语句:

  1. CREATE TABLE `person` (
  2. `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主键id',
  3. `age` int(2) COMMENT '年龄',
  4. `stature` int(3) ZEROFILL COMMENT '身高',
  5. PRIMARY KEY (`id`)
  6. ) ENGINE=InnoDB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;

​ 其中列 id 、 age、stature都是整型 。其中int后面括号中的数字指的是列宽,用M表示。对于整数类型,M表示最大显示宽度。最大显示宽度为255。显示宽度与类型可以存储的值范围无关。

我们来添加几条数据测试:

  1. INSERT INTO person( age, stature) VALUES(102,168);
  2. INSERT INTO person( age, stature) VALUES(5,80);
  3. INSERT INTO person( age, stature) VALUES(99999,99999);

查询结果:

id age stature
1 102 168
2 5 080
3 99999 99999
  • age我们设置的宽度是2,但是没有增加ZEROFILL属性,这个时候,不论是INT(2)还是INT(11),它在数据库里面存储的都是4个字节的长度,没有任何区别。
  • stature我们设置的快读是3,并且设置了ZEROFILL属性,那么我们插入的长度小于3,前面就补0,如080,如果长度大于3,如99999,则也可以正常插入。

注意我使用 Navicat 查询的时候,第三条记录显示不正确(少了几个9),但是使用命令行查询则正确。

如果为数值列指定了ZEROFILL, MySQL会自动将UNSIGNED属性添加到该列。

  1. INSERT INTO person( age, stature) VALUES(25,-80);

结果如下,说明stature已经是非负整数了:

  1. INSERT INTO person( age, stature) VALUES(25,-80)
  2. > 1264 - Out of range value for column 'stature' at row 1
  3. > 时间: 0.004s

​ 从MySQL 8.0.17开始,对于数字数据类型,不建议使用ZEROFILL属性,并且在将来的MySQL版本中将不再支持该属性。 考虑使用替代方法来产生此属性的效果。 例如,应用程序可以使用 LPAD() 函数将数字零填充到所需宽度,或者将格式化的数字存储在CHAR列中。

总结:

  1. 不加 ZEROFILL 属性,int(1) 和 int(11)没有任何区别,底层数据都是4个字节,注意字段显示宽度最大为255.
  2. 加上 ZEROFILL 属性,列默认为无符号,并且值宽度小于显示宽度会在左边补0,大于显示宽度则正常显示。
  3. 不建议使用 ZEROFILL 属性,使用LPAD函数代替此功能。

MySQL数据类型-整型的更多相关文章

  1. mysql数据类型——整型INT(m)

    1.整形分为四种 tinyint smallint mediumint int bigint 注意: 右侧的取值范围是在未加unsigned关键字的情况下,如果加了unsigned,则最大值翻倍,如t ...

  2. GOLANG 基本数据类型 整型

    基本数据类型-整型 种类     有符号(负号)      int8 int16 int32 int64 无符号(无符号) uint8 uint16 uint32 uint64 架构特定(取决于系统位 ...

  3. Golang的基础数据类型-整型

    Golang的基础数据类型-整型 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.整型概述 Go语言的整数类型一共有10个. int: 默认是有符号(signed)整形,占用空间 ...

  4. GO语言学习——基本数据类型——整型、浮点型、复数、布尔值、fmt占位符

    基本数据类型 整型 整型分为以下两个大类: 按长度分为:int8.int16.int32.int64 对应的无符号整型:uint8.uint16.uint32.uint64 其中,uint8就是我们熟 ...

  5. mysql之整型数据int

    mysql数据库设计,其中,对于数据性能优化,字段类型考虑很重要,mysql整型bigint.int.mediumint.smallint 和 tinyint的语法介绍,如下:1.bigint 从 - ...

  6. python基础知识2——基本的数据类型——整型,长整型,浮点型,字符串

    磨人的小妖精们啊!终于可以归置下自己的大脑啦,在这里我要把--整型,长整型,浮点型,字符串,列表,元组,字典,集合,这几个知识点特别多的东西,统一的捯饬捯饬,不然一直脑袋里面乱乱的. 对于Python ...

  7. 第一节 Python基础之数据类型(整型,布尔值,字符串)

    数据类型是每一种语言的基础,就比如说一支笔,它的墨有可能是红色,有可能是黑色,也有可能是黄色等等,这不同的颜色就会被人用在不同的场景.Python中的数据类型也是一样,比如说我们要描述一个人的年龄:小 ...

  8. python02 运算符,基本数据类型,整型,字符串

    1.python开发IDE pycharm,python编写工具,, #专业版 #不需要汉化 注册码问题解决 https://www.cnblogs.com/evlon/p/4934705.html整 ...

  9. [日常] Go语言圣经--作用域,基础数据类型,整型

    go语言圣经-作用域 1.一个声明语句将程序中的实体和一个名字关联,比如一个函数或一个变量 2.一个变量的生命周期是指程序运行时变量存在的有效时间段;声明语句的作用域对应的是一个源代码的文本区域,它是 ...

随机推荐

  1. Javascript | DOM\DOM树浅析

    DOM Document Object Model(文档对象模型) 定义了表示和修改文档所需的方法. DOM对象即为宿主对象,由浏览器厂商定义,用来操作html和xml功能的一类对象的集合.也有人称D ...

  2. CSS中如何设置父元素透明度不影响子元素透明度

    原因分析: 使用css的opcity属性改变某个元素的透明度,但是其元素下的子元素的透明度也会被改变,即便重定义也没有用,不过有个方法可以实现,大家可以看看. 可以使用一张透明的图片做背景可以达成效果 ...

  3. Solr的学习使用之(五)添加索引数据

    1.创建SolrServer类 SolrServer类:提供与Solr实例的连接与通信. 往Solr里添加索引数据,据说有好几种办法,这边利用SolrJ操作solr API完成index操作,具体So ...

  4. UNIX网络编程总结三

    套接口结构 IPv4套接口地址结构: 1 2 3 4 5 6 7 struct sockaddr_in{/*16字节*/ uint8_t sin_len;  /*结构体长度,8位*/ sa_famil ...

  5. Invalid operator< assertion error解析

    这两天忙着在准备3月份打PAT考试,许久没有接触刷题了,各种生疏各种忘记,刷题速度那是一个慢,真是为自己智商着急.今天刷题碰到了一个有意思的编程习惯性错误,好几道题都涉及到自定义排序,需要自己重写&l ...

  6. maven 常用插件 拷贝依赖 拷贝jar包 查看属性 环境变量

    1 maven编译后希望将生产的jar包拷贝到指定目录 在pom中配置maven插件 maven-antrun-plugin <build > <plugins> <pl ...

  7. vue的keep-alive组件

    keep-alive是Vue提供的一个抽象组件,用来对组件进行缓存,从而节省性能,由于是一个抽象组件,所以在v页面渲染完毕后不会被渲染成一个DOM元素 <keep-alive> <l ...

  8. LeetCode--058--最后一个单词(java)

    给定一个仅包含大小写字母和空格 ' ' 的字符串,返回其最后一个单词的长度. 如果不存在最后一个单词,请返回 0 . 说明:一个单词是指由字母组成,但不包含任何空格的字符串. 示例: 输入: &quo ...

  9. mysql 1067 - Invalid default value for 'addtime'错误处理

    错误描述 TABLE `bota_payment_closing` ( `id` int(11) NOT NULL AUTO_INCREMENT, `monthly` varchar(8) NOT N ...

  10. Gym - 101194H Great Cells

    Problem H. Great Cells 题目链接:https://codeforces.com/gym/101194/attachments Input file: Standard Input ...