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

mysql中int和bigint

基础概念

MySQL中的INTBIGINT是两种整数数据类型,用于存储整数值。它们的主要区别在于存储范围和存储空间。

  • INT:占用4个字节(32位),可以存储的整数范围是-2,147,483,648到2,147,483,647。
  • BIGINT:占用8个字节(64位),可以存储的整数范围是-9,223,372,036,854,775,808到9,223,372,036,854,775,807。

相关优势

  • INT:适用于大多数常规整数存储需求,因为它占用的存储空间较小,查询速度相对较快。
  • BIGINT:适用于需要存储非常大整数的场景,如自增ID、时间戳等。

类型

  • INT:有符号和无符号两种类型。无符号INT的范围是0到4,294,967,295。
  • BIGINT:同样有符号和无符号两种类型。无符号BIGINT的范围是0到18,446,744,073,709,551,615。

应用场景

  • INT:通常用于存储用户ID、订单ID、评分等。
  • BIGINT:常用于存储自增主键、时间戳(如UNIX时间戳)、大范围的计数器等。

常见问题及解决方法

问题:为什么使用BIGINT而不是INT?

原因:当需要存储的整数超出INT的范围时,必须使用BIGINT。例如,如果你的系统需要生成一个唯一标识符,而这个标识符的值可能会超过INT的最大值,那么就需要使用BIGINT。

解决方法

代码语言:txt
复制
CREATE TABLE example (
    id BIGINT AUTO_INCREMENT PRIMARY KEY,
    name VARCHAR(255)
);

问题:使用BIGINT会带来什么性能影响?

原因:由于BIGINT占用更多的存储空间,可能会导致表的大小增加,从而影响查询性能。此外,处理更大的整数也会稍微增加CPU的负担。

解决方法

  • 尽量只在必要时使用BIGINT。
  • 使用索引来优化查询性能。
  • 如果可能,考虑使用其他数据类型或存储方案,如UUID。

问题:如何选择合适的数据类型?

解决方法

  • 根据实际需求选择合适的数据类型。如果整数值不会超过INT的范围,尽量使用INT以节省存储空间。
  • 如果需要存储非常大的整数,或者需要更高的精度,选择BIGINT。

参考链接

通过以上信息,你应该能够更好地理解MySQL中的INTBIGINT数据类型,并根据具体需求选择合适的数据类型。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • MySQL中int、bigint、smallint 和 tinyint的区别详细介绍

    最近使用mysql数据库的时候遇到了多种数字的类型,主要有int,bigint,smallint和tinyint。其中比较迷惑的是int和smallint的差别。...P.S. bigint已经有长度了,在mysql建表中的length,只是用于显示的位数 int 从 -2^31 (-2,147,483,648) 到 2^31 – 1 (2,147,483,647...在 SQL Server 中,int 数据类型是主要的整数数据类型。 在数据类型优先次序表中,bigint 位于 smallmoney 和 int 之间。...只有当参数表达式是 bigint 数据类型时,函数才返回 bigint。SQL Server 不会自动将其它整数数据类型(tinyint、smallint 和 int)提升为 bigint。...int(M) 在 integer 数据类型中,M 表示最大显示宽度。在 int(M) 中,M 的值跟 int(M) 所占多少存储空间并无任何关系。

    6.2K30

    mysql中int、bigint、smallint 和 tinyint的区别和存储的范围

    部门中有个字段存储的是十进制数字 , 但是表示的意思是转成二进制后 ,每一个位代表不同功能的开关状态 当超过32个功能开关的时候 , 就需要将int类型转换成bigint类型 , 原因就是int只能存储...4个字节也就是2的32次方的整型值 , 装不下了, 下面就是具体的存的范围 bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807...int 从 -2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 的整型数据(所有数字)。存储大小为 4 个字节。...int 的 SQL-92 同义字为 integer。 smallint 从 -2^15 (-32,768) 到 2^15 - 1 (32,767) 的整型数据。存储大小为 2 个字节。...注释 在支持整数值的地方支持 bigint 数据类型。但是,bigint 用于某些特殊的情况,当整数值超过 int 数据类型支持的范围时,就可以采用 bigint。

    1.5K10

    int、bigint、smallint 和 tinyint范围「建议收藏」

    1 bytes = 8 bit ,一个字节最多可以代表的数据长度是2的8次方 11111111 在计算机中也就是   -128到127   1.BIT[M]   位字段类型,M表示每个值的位数,范围从...int 的 SQL-92 同义字为 integer。   普通大小的整数。带符号的范围是-2147483648到2147483647。无符号的范围是0到4294967295。   ...7.BIGINT[(M)] [UNSIGNED] [ZEROFILL] M默认为20 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807...注意:这里的M代表的并不是存储在数据库中的具体的长度,以前总是会误以为int(3)只能存储3个长度的数字,int(11)就会存储11个长度的数字,这是大错特错的。...tinyint(1) 和 tinyint(4) 中的1和4并不表示存储长度,只有字段指定zerofill是有用, 如tinyint(4),如果实际值是2,如果列指定了zerofill,查询结果就是0002

    4.4K30

    mysql的数据类型int、bigint、smallint 和 tinyint取值范围

    int 从 -2^31 (-2,147,483,648) 到 2^31 - 1 (2,147,483,647) 的整型数据(所有数字)。存储大小为 4 个字节。...int 的 SQL-92 同义字为 integer。 smallint 从 -2^15 (-32,768) 到 2^15 - 1 (32,767) 的整型数据。存储大小为 2 个字节。...注释 在支持整数值的地方支持 bigint 数据类型。但是,bigint 用于某些特殊的情况,当整数值超过 int 数据类型支持的范围时,就可以采用 bigint。...在 SQL Server 中,int 数据类型是主要的整数数据类型。 在数据类型优先次序表中,bigint 位于 smallmoney 和 int 之间。...只有当参数表达式是 bigint 数据类型时,函数才返回 bigint。SQL Server 不会自动将其它整数数据类型(tinyint、smallint 和 int)提升为 bigint。

    4.3K31

    Mysql中int和varchar类型

    int类型: int bigint smallint 和 tinyint 类型,如果创建新表时没有指定 int(M) 中的M时,默认分别是 : int           -------     int...tinyint(4) MySQL支持选择在该类型关键字后面的括号内指定整数值的显示宽度(例如,INT(4))。...int(M) 在 integer 数据类型中,M 表示最大显示宽度,该可选显示宽度规定用于显示宽度小于指定的列宽度的值时从左侧填满宽度。...在 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长度的问题

    1.7K10

    使用INT4INT类型替换INT8BIGINT类型能够节省多少磁盘空间?

    使用INT4/INT类型替换INT8/BIGINT类型能够节省多少磁盘空间? 最近有人在IRC,Slack和Reddit上讨论使用int4/integer替代int8/bigint能够少4个字节。...但是如果有int4,下一个列超过4字节,PG不会将另一个列拆分为“前一个8字节的4个字节的一部分,下一个中的一部分”,一切都将转到下一个8字节块中。...│ 8 │ 1 (7 rows) 对于每一行,都有tableoid、cmax、xmax、cmin和ctid(tableoid和ctid在数据文件中并不存在),然后再表格中有“...由于都是texts,估算每行大小比较复杂,但是假设他们每个只占8个字节块,鉴于列的排列方式,只有第25和26列可以放入单个8字节块中。...-int-instead-of-int8-bigint/

    79440

    聊聊Mysql中的int(1)

    昨天有个读者问了我这样一个问题在mysql中建表的时候,我设置一个字段为int类型,长度为1,但是我发现这个字段却可以存储任意长度的数字,这是什么情况?...0 和 1 是计算机最基本的存储单位。也是 CPU 采用的最基本的计算单位,也就是二进制。...现在再来看看这个int(1)中的1究竟有什么奥秘。这个1跟这个字段能存的数据范围没关系,它也不是限制这个字段的数据长度的。这个字段存储的数据范围是由int来限制的。...mysql对于整型的数据类型,不仅给我们提供了int,还提供了tinyint,smallint,mediumint和bigint。...如果数据量够够够够大,你选择bigint做为自增主键肯定没啥问题。这个数字我已经读不出来了,交给评论区的你们来读!

    1.9K20

    mysql中int长度的意义

    提问: 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 (10) 和 int (11) 的区别

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

    1.8K30

    如何将生产环境的字段类型从INT修改为BIGINT

    本文描述了我如何计划和执行从INT到BIGINT数据类型的更改。该技术在单独的SQL服务器实例上创建表的新副本,并使用BIGINT数据类型,然后使用对象级恢复将其移到生产数据库中。...这需要将所有数据复制到一个新表中,创建所有索引和约束,然后创建一个触发器,以确保插入两个表。我个人怀疑这个方案是否满足条件,包括维护和性能。 另一个方案就是建议使用INT的负值。...就是去创建一个副本表,唯一不同就是使用BIGINT代替INT,然后小批量的赋值数据,保证两个表示同步,通过使用cdc或者触发器来捕捉原表的修改完成对目标表的插入。...我们在验收环境中运行了一个试点,模拟了我们的生产设置,并且运行良好。 在验收和生产过程中,流程按照以下步骤进行: 将生产数据库的完整数据库备份恢复到开发/测试环境。...在还原的数据库中,用BIGINT代替INT创建副本表。 创建SSIS包,并启IDENTITY INSERT ,传输数据。 在复制表上创建所有索引和约束。

    3K10

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

    最后查出的结果是:这里的M代表的并不是存储在数据库中的具体的长度,以前总是会误以为int(3)只能存储 3个长度的数字,int(11)就会存储 11 个长度的数字,这是大错特错的。...0 2 知识点 int(M) 中的M指示最大显示宽度,最大有效显示宽度是 255,且显示宽度与存储大小或类型包含的值的范围无关。...作为 SQL 标准的扩展,MySQL 也支持整数类型TINYINT、MEDIUMINT 和 BIGINT。下面的表显示了需要的每个整数类型的存储和范围。 ?...MySQL 类型关键字后面的括号内指定整数值的显示宽度(例如,INT(4))。该可选显示宽度规定用于显示宽度小于指定的列宽度的值时从左侧填满宽度。...0 3 总结 所以,int(2) 与int(11)后的括号中的字符表示显示宽度,整数列的显示宽度与 MySQL 需要用多少个字符来显示该列数值,与该整数需要的存储空间的大小都没有关系,int类型的字段能存储的数据上限依旧是

    4.3K30

    如何将生产环境的字段类型从INT修改为BIGINT

    本文描述了我如何计划和执行从INT到BIGINT数据类型的更改。该技术在单独的SQL服务器实例上创建表的新副本,并使用BIGINT数据类型,然后使用对象级恢复将其移到生产数据库中。...这需要将所有数据复制到一个新表中,创建所有索引和约束,然后创建一个触发器,以确保插入两个表。我个人怀疑这个方案是否满足条件,包括维护和性能。 另一个方案就是建议使用INT的负值。...就是去创建一个副本表,唯一不同就是使用BIGINT代替INT,然后小批量的赋值数据,保证两个表示同步,通过使用cdc或者触发器来捕捉原表的修改完成对目标表的插入。...我们在验收环境中运行了一个试点,模拟了我们的生产设置,并且运行良好。 在验收和生产过程中,流程按照以下步骤进行: 将生产数据库的完整数据库备份恢复到开发/测试环境。...在还原的数据库中,用BIGINT代替INT创建副本表。 创建SSIS包,并启IDENTITY INSERT ,传输数据。 在复制表上创建所有索引和约束。

    5.1K80

    【MySQL 】MySQL 中的 int(11) 到底代表什么意思?

    一、前言   在工作中经常要与 mysql 打交道,但是对 mysql 的各个字段类型一直都是一知半解,因此写本文总结记录一番。 二、简介 ?   ...代表的并不是长度,而是字符的显示宽度,在字段类型为 int 时,无论你显示宽度设置为多少,int 类型能存储的最大值和最小值永远都是固定的,这里贴一些原文片段。   ...(BIGINT values)....那么照文中所说,所以无论怎么设置 int 类型的显示宽度,int 所能存储的最大值和最小值是固定的,那么这个显示宽度到底有什么用呢?   ...三、结论 从上个例子我们可以得出以下几个结论:   1、如果一个字段设置了无符号和填充零属性,那么无论这个字段存储什么数值,数值的长度都会与设置的显示宽度一致,如上述例子中的字段 b,插入数值 1 显示为

    3.3K20
    领券