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

mysqlint长度的意义

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

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

    详解 mysql int 类型的长度值问题

    秉着好奇心, 打开了 google ~ 引入大神的解答. mysql 在建表的时候 int 类型后的长度代表什么? 该列允许存储值的最大宽度吗?...为什么我设置成 int(1), 也一样能存 10,100,1000 呢. 当时我虽然知道 int(1), 这个长度 1 并不代表允许存储的宽度, 但却没有一个合理的解释....或者说对这个长度也没有真正的研究过到底代表什么, 平时都用 int(11), 也不知道为什么要 11 位....所以我在网上查阅了一些资料, 也仔细的看了 mysql 手册关于 int data type 的说法. 以下每个整数类型的存储和范围 (来自 mysql 手册) ?...0, 最大值为 4294967295(即 4B=32b, 最大值即为 32 个 1 组成); 接下来我们再说说我们建表时的字段长度到底怎么一回事.

    3.5K20

    mysqlint(5) 到底有多长?

    在设计 mysql 表字段时,int(5) 表示该字段长度为 5 吗?如果你觉得,那请你继续往下看,相信你会有新的收获的。...#插入一条大数据 insert into test (length) values (123456789); 结果证明 int(5) 能插入长度大于 5 的数据,所以现在可以肯定的 int(5) 并不是代表数据的宽度...int 字段长度其实是固定的,就是 4 个字节,不管你 int(11)  还是 int(5) 字段长度就是固定的 4 个字节。...#int(5) length 字段添加了 zerofill 属性 mysql> select * from test; +----+--------+ | id | length | +----+---...tinyint、smallint、mediumint、int、bigint 这几个类型,这几个整数类型才代表了固定的长度,具体长度请看下面这个表格。

    2.2K30

    MySQLint (10) 和 int (11) 的区别

    127 | +----+-----------+-----------+ 3 rows in set (0.00 sec) 查询出来的结果也是一样,经过以上实验得到结论: 显示宽度整数类型的取值范围无关的...同理,所以 int (10) 和 int (11) 无任何区别,就是显示宽度不同。...在存储方面确实没什么不同,设置长度只有在设置了自动填充 ZEROFILL 的时候才体现出来, 比如 id=1 长度int (5) 的话会显示 00001。...Mysql 可以为整数类型指定宽度,例如 INT (11),对大多数应用这是没有意义的:他不会限制值的合法范围,只是规定了 Mysql 的一些交互工具,如 Mysql 命令行客户端,用来显示字符的个数。...对于存储和运算来说, INT (1) 和 INT (8) 相同的。 是的,设置自动填充的时候用来显示补充0有点 用而已

    1.8K30

    Mysql覆盖索引_mysql索引长度限制

    只扫描索引而无需回表的优点: 1.索引条目通常远小于数据行大小,只需要读取索引,则mysql会极大地减少数据访问量。...2.因为索引按照列值顺序存储的,所以对于IO密集的范围查找会比随机从磁盘读取每一行数据的IO少很多。...,但不是整个查询涉及的字段,mysql5.5和之前的版本也会回表获取数据行,尽管并不需要这一行且最终会被过滤掉。...2.mysql不能在索引中执行LIke操作。mysql能在索引中做最左前缀匹配的like比较,但是如果通配符开头的like查询,存储引擎就无法做比较匹配。...5.5时API设计不允许mysql将过滤条件传到存储引擎层(把数据从存储引擎拉到服务器层,在根据条件过滤),5.6之后由于ICP这个特性改善了查询执行方式 译者介绍:家华,从事mysqlDBA的工作,

    7.9K30

    聊聊Mysql中的int(1)

    昨天有个读者问了我这样一个问题在mysql中建表的时候,我设置一个字段为int类型,长度为1,但是我发现这个字段却可以存储任意长度的数字,这是什么情况?...这个字段存储的数据范围int来限制的。...这个1只规定了数据的宽度,如果你选择了Zerofill属性,就能更好地理解这个1了,如果我们写入的数据达不到这个长度,那么就会在数据前面补0来达到这个长度。...比如我们将int(1)改成int(3),我们再输入1,实际上显示的001。所以无论你将 int 类型的长度设为多少并不会影响数据的存储范围。...mysql对于整型的数据类型,不仅给我们提供了int,还提供了tinyint,smallint,mediumint和bigint。

    1.9K20

    mysql前缀索引 默认长度_如何确定前缀索引的长度

    MySQL5.7里默认 innodb_large_prefix=1 解除了767bytes长度限制,但是单列索引长度最大还是不能超过3072bytes。...至于为什么767字节,依赖于具体的存储引擎实现的,找了官方文档,也没说为啥。...https://dev.mysql.com/doc/refman/8.0/en/create-index.html varchar(n)占用几个字节跟字符集有关系: 字符类型若为gbk,每个字符占用2个字节...所以我们经常会见到把字段设置成varchar(255)长度的,在utf8字符集下这个最大不超过767bytes的长度了,但是并不是一定要设置成varchar(255),还是要根据业务设置每个字段的长度...解决办法 可以直接去改字段的长度,或者说,把索引的字段取消掉一些,但是这样改对表本身不友好的。 通过限定字段的前n个字符为索引,可以通过衡量实际的业务中数据中的长度来取具体的值。

    3.6K20

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

    0 1 引言 依稀还记得有次面试,有面试官问我int(10)与int(11)有什么区别,当时觉得就是长度的区别吧!面试官最后也没有给反馈,我也就以为自己答对了。...最后查出的结果:这里的M代表的并不是存储在数据库中的具体的长度,以前总是会误以为int(3)只能存储 3个长度的数字,int(11)就会存储 11 个长度的数字,这是大错特错的。...从声明字段 int 类型的那一刻起,int就是占四个字节,一个字节 8 位,也就是4*8=32,可以表示的数字个数 2 的 32 次方(2^32 = 4 294 967 296个数字)。...关键字 INT INTEGER 的同义词,关键字 DEC DECIMAL 的同义词。 BIT 数据类型保存位字段值,并且支持 MyISAM、MEMORY、InnoDB 和 BDB表。...0 3 总结 所以,int(2) 与int(11)后的括号中的字符表示显示宽度,整数列的显示宽度与 MySQL 需要用多少个字符来显示该列数值,与该整数需要的存储空间的大小都没有关系,int类型的字段能存储的数据上限依旧

    4.3K30

    ​byte加byte居然int了?

    Idea给的提示可以看到,两个 byte 类型相加的结果变成了 int 类型,不能赋值给一个 byte 类型变量。...其实不只是 byte,包括:short、char 等类型执行运算之后的结果也变成 int 类型了,不再参与运算之前的类型。...如果想要上述代码能够正常编译和运行,可以修改为如下的写法:// 写法一byte a = 1;byte b = 2;b = (byte) (a + b);// 写法二(这种写法上面写法的一种简化写法,具体可以见...类型,由于两个数都提升为了 int 类型,它们执行的运算结果自然而然也就是 int 类型的了。...在 JVM 的操作数栈的一个单位长度 32 位,因此为了把参与运算的数放到操作数栈中就必须对其进行扩展,同时我理解这里也是为了和局部变量表的单位相匹配,局部变量表的基本单位槽位,一个槽位的宽度也是

    300

    MySQL中索引的长度的限制

    参考: http://dinglin.iteye.com/blog/1681332 单列索引的长度的限制     (5.6里面默认不能超过767bytes,5.7不超过3072bytes):     起因...这个3字符最大占用空间(utf8)。但是在5.5以后,开始支持4个字节的uutf8。...255×4>767, 于是增加了一个参数叫做 innodb_large_prefix     # 256的由来: 只是因为char最大255,所以以前的程序员以为一个长度为255的index就够用了,...--- by 阿里-丁奇 在MySQL5.6里默认 innodb_large_prefix=0 限制单列索引长度不能超过767bytes    官网文档:https://dev.mysql.com/doc...在MySQL5.7里默认 innodb_large_prefix=1 解除了767bytes长度限制,但是单列索引长度最大还是不能超过3072bytes 联合索引的长度的限制 (不能超过3072bytes

    5.4K30
    领券