首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQLint (10) 和 int (11) 区别

mysql 中整数数据类型 不同类型取值范围 不同数据类型默认显示宽度 显示宽度跟负号没有关系,它只在人工设置了 ZEROFILL 属性有效。...显示宽度只是指明 mysql 最大可能显示数字个数,数值位数小于指定宽度时左侧用数字 0 填充。...如果插入了大于显示宽度值,只要该值不超过该类型整数取值范围,数值依然可以插入,而且能够显示出来。 同理,所以 int (10) 和 int (11) 无任何区别,就是显示宽度不同。...Mysql 可以为整数类型指定宽度,例如 INT (11),对大多数应用这是没有意义:他不会限制值合法范围,只是规定了 Mysql 一些交互工具,如 Mysql 命令行客户端,用来显示字符个数。...对于存储和运算来说, INT (1) 和 INT (8) 是相同。 是的,设置自动填充时候用来显示补充0有点 用而已

1.8K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    聊聊Mysqlint(1)

    昨天有个读者问了我这样一个问题在mysql中建表时候,我设置一个字段为int类型,长度为1,但是我发现这个字段却可以存储任意长度数字,这是什么情况?...这个问题在我刚接触数据库时候也遇到过,我觉得有必要写一篇文章来解释一下。 0 和 1 是计算机最基本存储单位。也是 CPU 采用最基本计算单位,也就是二进制。...比如我们将int(1)改成int(3),我们再输入1,实际上显示是001。所以无论你将 int 类型长度设为多少并不会影响数据存储范围。...mysql对于整型数据类型,不仅给我们提供了int,还提供了tinyint,smallint,mediumint和bigint。...很多小伙伴是不是心中飘过一万匹草泥马,忙着修改数据库去了。这其实大可不必担心,这个数字大概是42亿。如果数据量够够够够大,你选择bigint做为自增主键肯定没啥问题。

    1.8K20

    mysqlint长度意义

    提问: mysql字段,unsigned int(3), 和unsinged int(6), 能存储数值范围是否相同。如果不同,分别是多大?...回答: 不同,int(3)最多显示3位无符号整体,int(6)最多显示6位无符号数。 如果你答案和上面的一致,恭喜你和我犯了一样错误。...发现,无论是int(3), int(6), 都可以显示6位以上整数。但是,当数字不足3位或6位时,前面会用0补齐。...查下手册,解释是这样MySQL还支持选择在该类型关键字后面的括号内指定整数值显示宽度(例如,INT(4))。该可选显示宽度规定用于显示宽度小于指定列宽度值时从左侧填满宽度。...也就是说,int长度并不影响数据存储精度,长度只和显示有关,为了让大家看更清楚,我们在上面例子建表语句中,使用了zerofill。

    3.9K10

    MYSQL 数据库时间字段 INT,TIMESTAMP,DATETIME 性能效率比较

    原文 | http://1t.click/FAB 在数据库设计时候,我们经常会需要设计时间字段,在 MYSQL 中,时间字段可以使用 int、timestamp、datetime 三种类型来存储,那么这三种类型哪一种用来存储时间性能比较高...('1970-01-08 06:40:00') 查询花费 0.3824 秒 对于 int 类型,有索引效率反而低了,笔者估计是由于设计表结构问题,多了索引,反倒多了一个索引查找。...d_int<UNIX_TIMESTAMP('1970-01-08 06:40:00') 查询花费 0.3092 秒 InnoDB 引擎查询效率明细比 MyISAM 引擎低,低 3 倍+。...d_timestamp)>400000 AND UNIX_TIMESTAMP(d_timestamp)<600000 查询花费 0.2944 秒 对于 timestamp 类型,有了索引,反倒不建议使用 MYSQL...d_datetime)>400000 AND UNIX_TIMESTAMP(d_datetime)<600000 查询花费 0.9994 秒 对于 datetime 类型,同样有了索引,反倒不建议使用 MYSQL

    7K30

    mysql数据库int类型最大值_mysql自增主键最大值

    大家好,又见面了,我是你们朋友全栈君。 1、mysqlint(11)中11代表显示宽度 整数列显示宽度,与mysql需要用多少个字符来显示该列数值,与该整数需要存储空间大小都没有关系。...a、int是整型,(11)是指显示字符宽度,最大为255。 b、int(11)是记录行数id,插入10条记录,那么它就显示00000000001 ~~~00000000010。...c、当字符位数超过11,它也只显示11位。 d、如果没有加未满11位就前面加0参数,就不会在前面加0。 e、如果没有给它指定显示宽度,MySQL会为它指定一个默认值。...f、INT(3)会占用4个字节存储空间,并且允许最大值也不会是999,而是INT整型所允许最大值。...2、mysql有五种整型数据列类型,即TINYINT,SMALLINT,MEDIUMINT,INT和BIGINT。 a、区别是取值范围不同,存储空间不相同。

    6.2K20

    MySQLMySQL int(11) 到底代表什么意思?

    一、前言   在工作中经常要与 mysql 打交道,但是对 mysql 各个字段类型一直都是一知半解,因此写本文总结记录一番。 二、简介 ?   ...对于 int 类型一些基础知识其实上图已经说很明白了,在这里想讨论下常用 int(11) 代表什么意思,很长时间以来我都以为这代表着限制 int 长度为 11 位,直到有天看到篇文章才明白,11...代表并不是长度,而是字符显示宽度,在字段类型为 int 时,无论你显示宽度设置为多少,int 类型能存储最大值和最小值永远都是固定,这里贴一些原文片段。   ...那么照文中所说,所以无论怎么设置 int 类型显示宽度,int 所能存储最大值和最小值是固定,那么这个显示宽度到底有什么用呢?   ...当 int 字段类型设置为无符号且填充零(UNSIGNED ZEROFILL)时,当数值位数未达到设置显示宽度时,会在数值前面补充零直到满足设定显示宽度,为什么会有无符号限制呢,是因为 ZEROFILL

    3.2K20

    Mysqlint和varchar类型

    int类型: int bigint smallint 和 tinyint 类型,如果创建新表时没有指定 int(M) 中M时,默认分别是 : int           -------     int...显示宽度并不限制可以在列内保存范围,也不限制超过列指定宽度显示。 在 int(M) 中,M 值跟 int(M) 所占多少存储空间并无任何关系。...和数字位数也无关系, int(3)、int(4)、int(8) 在磁盘上都是占用 4 btyes 存储空间。 上面几种类型存储范围见下图: 如何计算一个字节能够存储整数位数?...2个字节有16位,无符号从0000 0000 0000 0000(0)到1111 1111 1111 1111(2^16-1) 有符号:(-2^15到2^15-1) mysql中设置varchar长度问题...mysql varchar(50) 不管中文 还是英文 都是存50个

    1.7K10

    详解 mysql int 类型长度值问题

    创建数据库时候发现一个问题: 改变 length 值, 不能影响到实际存储长度!...秉着好奇心, 打开了 google ~ 引入大神解答. mysql 在建表时候 int 类型后长度代表什么? 是该列允许存储值最大宽度吗?...为什么我设置成 int(1), 也一样能存 10,100,1000 呢. 当时我虽然知道 int(1), 这个长度 1 并不代表允许存储宽度, 但却没有一个合理解释....所以我在网上查阅了一些资料, 也仔细看了 mysql 手册关于 int data type 说法. 以下是每个整数类型存储和范围 (来自 mysql 手册) ?...mysql 手册上还有这么一句话 "当 mysql 为某些复杂联结 (join) 生成临时表时,你可能会遇到问题,因为在这种情况下,mysql 信任地认为所有的值均适合原始列宽度".

    3.5K20

    不要再被MYSQLINT(M)给迷惑了

    MYSQL里有些比较隐晦知识点,经常被稀里糊涂用错而不自知。以前评审过程发生次数较多,索性随手写一些出来。前人栽个树,后人一定要乘凉啊!...表设计使用整型时,经常发现定义int括号里M是五花八门。误区是,不少人把M当成了数据库中存储最大长度,而实际上这个代表是显示宽度。只要是int类型,在数据库存储就一定是4个字节。...当一个数值列类型被定义成zerofill时,查询此列MYSQL会自动在数值左侧填充0直到M长度,若数值长度已超过M, 则无需填充0; 2....Step 4 > 简单解读一下: - 不管M定义多长,INT可存储数值范围都由 4个字节 和 有无符号 来决定; - 超过最大值不报错,直接存储最大值; - 基于M显示宽度值来左填充0,只有声明zerofill...列才可以产生效果; 重申 > 若觉得使用int有点浪费,比如状态列,那可以使用tinyint, 千万不要想当然以为int(1)存是就一位数字,还沾沾自喜觉得节省了存储空间。

    1.5K31

    C# int int16 Int32 Int64介绍

    C# int int16 Int32 Int64介绍 今天看到别人代码中用到Int32,UInt32相关,想到自己平时用都是int类型整数,就心生好奇翻了一下资料: ---- Int32 值类型表示值介于...Int16 值类型表示值介于 -32768 到 +32767 之间有符号整数。...类型 范围 大小 .NETFramework 类型 short [-2^15 , 2^15 -1] 有符号16位数 System.Int16 int 关键字表示一种整型,该类型根据下表显示大小和范围存储值...类型 范围 大小 .NETFramework 类型 int [-2^31 , 2^31 -1] 有符号32位数 System.Int32 long 关键字表示一种整型,该类型根据下表显示大小和范围存储值...类型是unsigned int派生出来 int是带符号,表示范围是:-21474 83647 到 21474 83648 uint是不带符号整形,表示范围是0到42949 67295(2^32-1)

    3.1K30

    你对MySQLint(11)真的了解吗?

    你对MySQLint(11)真的了解吗? 最近在网上看到一篇关于int(3)和int(11)区别的帖子,我第一反应这不就是它们之间主要涉及存储整型数据时所需位数,即3位和11位差异。...mysql-int.jpg MYSQL int 数据存储范围 首先,需要明确是,int(3)和int(11)都是表示整数类型,而不是定义整数存储长度。...在mysql8.0 中,只有设置了ZEROFILL,才能看到int(),否则都是int 实际应用 我们在实际生产环境使用查询时候通常要把数据库int数据转化为java对象Integer,所以ZEROFILL...在实际生产中使用很少,其次我们需要给数据补齐位数时候通常是在程序中做处理,不会依赖数据库,这样我们业务才能更灵活。...总结 在数据库设计中,INT(3)和INT(11)区别主要在于它们控制输出时显示宽度。实际存储大小是相同,都占用4个字节。

    31510

    MySqlint(10)与int(11)有什么区别吗?

    最后查出结果是:这里M代表并不是存储在数据库具体长度,以前总是会误以为int(3)只能存储 3个长度数字,int(11)就会存储 11 个长度数字,这是大错特错。...我们通常在创建数据库时候都不会加入这个选项,所以可以说他们之间是没有区别的。...首先说一下 MySQL 数值类型,MySQL 支持所有标准 SQL 数值数据类型。...MySQL 类型关键字后面的括号内指定整数值显示宽度(例如,INT(4))。该可选显示宽度规定用于显示宽度小于指定列宽度值时从左侧填满宽度。...0 3 总结 所以,int(2) 与int(11)后括号中字符表示显示宽度,整数列显示宽度与 MySQL 需要用多少个字符来显示该列数值,与该整数需要存储空间大小都没有关系,int类型字段能存储数据上限依旧是

    4.3K30
    领券