首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MYSQL中int(11)数据类型面临的问题

MYSQL中int(11)数据类型面临的问题
EN

Stack Overflow用户
提问于 2011-08-13 12:23:50
回答 2查看 15.3K关注 0票数 1

我在MYSQL中有一个表,其主键id为int(11) (自动递增)。现在我有了一个程序,它可以读取一些文本文件并在id列中输入值。所以我的表应该包含:

代码语言:javascript
复制
id
897413
791783

但发生的情况是,我在我的表中找不到大数字。这是因为int(11)可以容纳的最大值吗?将int(11)增加到int(20)仍然面临同样的问题。我不能将数据类型更改为big int,因为我已经实现了很多代码。

编辑:我试图插入一条id为523826的记录,但它在数据库中被保存为450258。为什么会这样呢?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2011-08-13 12:32:47

int数据类型的mysql manual定义:

一个正常大小的整数。带符号的范围是-2147483648到2147483647。无符号范围是从0到4294967295。

int类型始终为4字节(32位)。int(11)中的11只是“显示宽度”,它只对UNSIGNED ZEROFILL列起作用。有关this blog post的更多详细信息。

票数 12
EN

Stack Overflow用户

发布于 2011-08-13 12:36:07

MySQL中的INT是32位。INT(11)很可能意味着您有一个带符号的INT,这对于ID是无用的。将其更改为unsigned INT将自动使可用ID的数量加倍(因为没有人使用负ID)。尽管11“看起来”更大,但这是因为如果它是11个字符长度的最大负数(-2147483648),那么它会考虑数字的“长度”。

BIGINT允许您使用64位,有符号的或无符号的。同样,unsigned将允许您使用两倍的ID (>0)。

正如Andrew上面提到的,如果您的PHP不支持64位整数,那么您将无法轻松地使用它们。

希望这能有所帮助。

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/7048553

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档