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

详解 mysql int 类型长度值问题

秉着好奇心, 打开了 google ~ 引入大神的解答. mysql 在建表的时候 int 类型后的长度代表什么? 是该列允许存储值的最大宽度吗?...为什么我设置成 int(1), 也一样能存 10,100,1000 呢. 当时我虽然知道 int(1), 这个长度 1 并不代表允许存储的宽度, 但却没有一个合理的解释....我们拿 int 类型例: int 类型, 占用字节数 4byte, 学过计算机原理的同学应该知道, 字节 (byte) 并非是计算机存储的最小单位, 还有比字节 (byte) 更小的单位, 也就是位...计算机存储单位的换算: 1B=8b 1KB=1024B 1MB=1024KB 那么根据 int 类型允许存储的字节数是 4 个字节, 我们就能换算出 intUNSIGNED(无符号) 类型的能存储的最小值...0, 最大值 4294967295(即 4B=32b, 最大值即为 32 个 1 组成); 接下来我们再说说我们建表时的字段长度到底是怎么一回事.

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

    mysqlint长度的意义

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

    3.9K10

    Mysqlint和varchar类型

    int类型int bigint smallint 和 tinyint 类型,如果创建新表时没有指定 int(M) 中的M时,默认分别是 : int           -------     int...支持选择在该类型关键字后面的括号内指定整数值的显示宽度(例如,INT(4))。...int(M) 在 integer 数据类型中,M 表示最大显示宽度,该可选显示宽度规定用于显示宽度小于指定的列宽度的值时从左侧填满宽度。...负数:从1 000 0000到1 111 1111(-(2^7-1)=-127) 负数在计算机中用补码表示-0的补码0000 0000与+0的表示一致,所以用0000 0000表示+0和-0。...2个字节有16位,无符号从0000 0000 0000 0000(0)到1111 1111 1111 1111(2^16-1) 有符号:(-2^15到2^15-1mysql中设置varchar长度的问题

    1.7K10

    聊聊Mysql中的int(1)

    昨天有个读者问了我这样一个问题在mysql中建表的时候,我设置一个字段int类型长度1,但是我发现这个字段却可以存储任意长度的数字,这是什么情况?...int 类型占 4 个字节,一个字节是 8 位,也就是说 int 类型在计算机底层是由 32 个 0 跟 1 表示,转化为十进制就是 2 的 32 次方,那么存储范围就是 0~2^32 ,如果带符号位的话就是...Zerofill:零填充,意思就是达不到指定长度后,前面用 0 来填充。 现在再来看看这个int(1)中的1究竟有什么奥秘。这个1跟这个字段能存的数据范围没关系,它也不是限制这个字段的数据长度的。...比如我们将int(1)改成int(3),我们再输入1,实际上显示的是001。所以无论你将 int 类型长度设为多少并不会影响数据的存储范围。...mysql对于整型的数据类型,不仅给我们提供了int,还提供了tinyint,smallint,mediumint和bigint。

    1.8K20

    mysql存储long型数据_int数据类型

    +2否则为D+2 依赖于M和D的值 依赖于M和D的值 小数值 INT 类型MySQL 中支持的 5 个主要整数类型是 TINYINT,SMALLINT,MEDIUMINT,INT 和 BIGINT...例如,指定一个字段的类型 INT(6),就可以保证所包含数字少于 6 个的值从数据库中检索出来时能够自动地用空格填充。需要注意的是,使用一个宽度指示器不会影响字段的大小和它可以存储的值的范围。...忽略 DECIMAL 数据类型的精度和计数方法修饰符将会使 MySQL 数据库把所有标识这个数据类型的字段精度设置 10,计算方法设置 0。...需要注意的是,没有冒号分隔符的 TIME 类型值,将会被 MySQL 理解持续的时间,而不是时间戳。...另外如果插入值的大小写与集合中值的大小写不匹配,MySQL 会自动使用插入值的大小写转换成与集合中大小写一致的值。 ENUM 类型在系统内部可以存储数字,并且从 1 开始用数字做索引。

    3.8K30

    MySQL修改字段类型、字段名字、字段长度、字段小数点长度

    文章目录 1:修改类型 2:修改长度 3: 同时修改列名和列的数据类型 4:修改字段类型text(类型) ~>mediumtext(类型) 5:修改字段长度和字段小数点长度 6: 修改字段列名和字段类型...7:指定字段之后新增字段 8:更新表content_text字段类型 9:修改字段类型,修改长度和小数点位数 1:修改类型 mysql> alter table 表名 modify column 字段名...mysql 修改字段类型:alter table news modify column title text;我发现使用这句sql也可以直接修改字段原本的类型!...city char(30);修改长度可以用(修改长度,要保证不短与已有数据,以保证原有数据不出错)mysql> alter table address modify column city varchar...content_text mediumtext; Query OK, 22 rows affected (0.06 sec) 5:修改字段长度和字段小数点长度 mysql> alter table buttontest

    10.5K20

    一文搞懂MySQL表字段类型长度的含义

    不知道大家第一眼看标题的时候有没有理解,什么是“字段类型长度”,这里我来解释下,就比如我们在MySQL建表的时候,比如下面这个建表语句:CREATE TABLE `user` ( `id` int(10...=utf8其中id、name、age是该表的三个不同字段,而每个类型+数字就是该字段的类型长度,比如int(10)就是该字段是int类型长度10,这下大家应该能理解什么是MySQL表字段类型长度了吧(...其实在后续的讲解中会发现这个并不是长度,而是宽度)那么重点问题来了,每一种类型后面括号里的数字都有什么含义呢,下面我们来剖析下:首先MySQL表的字段都支持哪些类型?...1 MySQL支持的数据类型1.1 类型分类分为几个大类:图片1.2 具体的数据类型细节数据类型如下:数值类型类型 大小(Bytes) 范围(有符号...,而是宽度,这个数字无论是大是小占用的存储都是一样的,无论是int类型还是varchar类型,我们看一个例子:CREATE TABLE `table03` ( `num1` int(10) DEFAULT

    1.3K11

    mysql数据类型详解(1

    整数 整数有两种类型:整数和实数。如果存储整数,可以使用几种整数类型:tinyint,smallint,mediumint,int或bigint,他们分别需要8,16,24,32,64位存储空间。...他们的范围-2(N-1)到2(N-1)-1,这里的n是所需存储空间的位数。 整数类型可选unsigned属性,它表示不允许负数,并大致把正上限提高一倍。...例如tinyint unsigned 保存范围0到255,而不是-127到128。 实数有分数部分。可以使用decimal保存比bigint还大的整数。mysql同时支持精度与非精度类型。...char是固定长度的。mysql总是特定数量的字符分配足够的空间,当保存char值的时候,mysql会去掉任何末尾的空格。存储很短的字符串或长度相似的字符串时候很有用。...char(1)字符串对于单字节字符集只会用1个字节,但是varchar(1)则会占用2个字节,因为1个字节用来存储长度信息。

    97180

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

    使用整数数据的精确数字数据类型。 bigint 从 -2^63 (-9223372036854775808) 到 2^63-1 (9223372036854775807) 的整型数据(所有数字)。...存储大小 8 个字节。 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 个字节。...存储大小 1 字节。 注释 在支持整数值的地方支持 bigint 数据类型。但是,bigint 用于某些特殊的情况,当整数值超过 int 数据类型支持的范围时,就可以采用 bigint。...在 SQL Server 中,int 数据类型是主要的整数数据类型。 在数据类型优先次序表中,bigint 位于 smallmoney 和 int 之间。

    4.3K31

    mysql面试题49:MySQL中不同text数据类型的最大长度

    该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入的回答,如果你想应付面试,是足够了,抓住关键点 面试官:MySQL中TEXT数据类型的最大长度MySQL中,TEXT数据类型用于存储较大的文本数据...以下是MySQL中不同TEXT类型的最大长度: TINYTEXT:最大长度255个字符(2^8-1)。 TEXT:最大长度65,535个字符(2^16-1)。...MEDIUMTEXT:最大长度16,777,215个字符(2^24-1)。 LONGTEXT:最大长度4,294,967,295个字符(2^32-1)。...需要注意的是,上述最大长度是以字符单位计算的,而不是以字节单位。对于非拉丁字符集(如UTF-8),一个字符可能占据多个字节的存储空间。...此外,MySQL还提供了BLOB数据类型,用于存储二进制大对象。

    37200

    MySQL核心知识》第5章:字段长度类型宽度

    ❞ 今天是《MySQL核心知识》专栏的第5章,今天跟大家一起聊聊MySQL的字段长度类型宽度。好了,开始今天的正题。...数据类型宽度 MYSQL中的整数型数据类型都可以指定显示宽度....创建一个表 CREATE TABLE tb_emp( id BIGINT(1)) id字段的数据类型BIGINT(1),注意到后面的数字1,这表示的是该数据类型指定的显示宽度,指定能够显示的数值中数字的个数...例如,假设声明一个INT类型的字段 YEAR INT(4) ,该声明指明,在year字段中的数据一般只显示4位数字的宽度。 显示宽度和数据类型的取值范围是无关的。...例如,向year字段插入一个数值19999,当使用select查询的时候,MYSQL显示的将是完整带有5位数字的19999,而不是4位数字的值 如果不指定显示宽度,则MYSQL每一种类型指定默认的宽度值

    1.4K30

    MySQL 保存日期,用哪种数据类型合适?datetime?timestamp?还是 int

    日期算是我们在日常开发中经常用到的数据类型,一般来说一张表都有 createTime 和 updateTime 字段,MySQL 中针对日期也提供了很多种不同的数据类型,如: datetime timestamp...那么到底该用哪种类型来保存日期呢? 1. 字符串 在这些类型中,首先应该排除掉的就是字符串了,很多新手小伙伴爱用字符串存储日期,但实际上这并不是一个很好的方案。...DATETIME VS TIMESTAMEP 2.1 占用空间 DATETIME 在数据库中存储的形式:YYYY-MM-DD hh:mm:ss,至于占用的字节数,则看情况,我们来看一段来自 MySQL...3. int 字符串费空间,TIMESTAMP 和 DATETIME 如果没有吃透则总感觉乱乱的,所以也有人存时间戳,存一个 int 类型的数值,用一个时间戳来表示时间。...不过 int 有一个致命的问题就是可读性太差,所以用不用 int 就要仔细斟酌看情况了。 好啦,小伙伴们留言说说你日常开发日期用的哪种类型呢?出于什么样的考虑用了该类型

    1.7K20
    领券