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

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

一旦人工设置了 ZEROFILL 属性,MySQL 会自动设置 UNSIGNED 属性(即 ZEROFILL 不能存储负数)。 那取值范围和显示宽度到底有什么关系呢?...如果插入了大于显示宽度的值,只要该值不超过该类型整数的取值范围,数值依然可以插入,而且能够显示出来。 同理,所以 int (10) 和 int (11) 无任何区别,就是显示宽度不同。...在存储方面确实没什么不同,设置长度只有在设置了自动填充 ZEROFILL 的时候才体现出来, 比如 id=1 长度为 int (5) 的话会显示 00001。...Mysql 可以为整数类型指定宽度,例如 INT (11),对大多数应用这是没有意义的:他不会限制值的合法范围,只是规定了 Mysql 的一些交互工具,如 Mysql 命令行客户端,用来显示字符的个数。...对于存储和运算来说, INT (1) 和 INT (8) 是相同的。 是的,设置自动填充的时候用来显示补充0有点 用而已

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

    面试官:说一下int(1)和int(11)的区别

    前言 了不起最近提了一个SQL工单alter table t_user ADD id int(1)。身边的同事看到后笑着说,你这int声明的长度为1,估计不够用!...实践 我们都知道MySQL中Int数据类型占用4个字节,那么对于无符号的Int,最大值是2^32-1,等于4294967295。那我们就创建一个测试表,把id的值直接干到顶,看下会不会报错。...创建测试表结构 CREATE TABLE `user` ( `id` int(1) unsigned NOT NULL AUTO_INCREMENT, PRIMARY KEY (`id`) )...(M)中,M的大小,并不影响int本身支持的数据范围,所以int(1)、int(11)其实没有什么区别。...MySQL官方解释 翻译如下: 对于整数数据类型,M 表示最小的显示宽度。最大的显示宽度为 255。显示宽度与类型可以存储的数值范围无关。 对于浮点数和定点数数据类型,M 表示可以存储的总位数。

    15810

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

    0 1 引言 依稀还记得有次面试,有面试官问我int(10)与int(11)有什么区别,当时觉得就是长度的区别吧!面试官最后也没有给反馈,我也就以为自己答对了。...最后查出的结果是:这里的M代表的并不是存储在数据库中的具体的长度,以前总是会误以为int(3)只能存储 3个长度的数字,int(11)就会存储 11 个长度的数字,这是大错特错的。...int(10)也可以代表 2147483647 这个值int(11)也可以代表。 要查看出不同效果记得在创建类型的时候加 zerofill这个值,表示用 0 填充,否则看不出效果的。...所有整数类型可以有一个可选(非标准)属性 UNSIGNED。当你想要在列内只允许非负数和该列需要较大的上限数值范围时可以使用无符号值。...0 3 总结 所以,int(2) 与int(11)后的括号中的字符表示显示宽度,整数列的显示宽度与 MySQL 需要用多少个字符来显示该列数值,与该整数需要的存储空间的大小都没有关系,int类型的字段能存储的数据上限依旧是

    4.3K30

    int和int32的区别_int float double char区别

    的别名,是等价的,short,long同理也是别名 详解Int32 为什么Int32 就等于 int, 很简单,在VS中写 int a=1; 选中a , F12转到定义就是System.Int32....但是一共还是能存储2^32次方 既42,9496,7296个数,因为有正负数,其实一样的,还是2的32次方个数 如图: 所以Int16和Int64也是同理的。...无符号整形Uint32 上面说的都是有符号整数,既signed integer, 就是可以储存正负数的,而无符号整数就是只能存储正数,既unsigned integer 在C#中用Uint16,UInt32...,Uint64等表示 跟上面同理 ushort =UInt16 uint =UInt32 ,0 ~ 4364967295 ulong =UInt64 UInt32和Int32一样 ,也是代表一共能存储...2^32次方,一共有42,9496,7296个数 但是因为只有正数和0,所以最大值为4364967295, 既2^32-1,-1是因为0占了一个数 溢出会如何 更进一步,尝试Int32 a=Int32

    2K50

    int和int32的区别_int是多少位的

    大家好,又见面了,我是你们的朋友全栈君。 大家有没有写了很久代码,还不知道这个Int8,Int16, Int32, Int64有什么区别呢?或者是为什么后面的数字不一样呢?...先来扫盲一下计算机存储单元,   在计算机内部,信息都是釆用二进制的形式进行存储、运算、处理和传输的。信息存储单位有位、字节和字等几种。...各种存储设备存储容量单位有KB、MB、GB和TB等几种 计算机的基本的存储单元有:   位(bit):二进制数中的一个数位,可以是0或者1,是计算机中数据的最小单位。...而Int8,Int16,Int32,nt64,后面的数字就代表这个数据类型占据的空间。 Int8, 等于Byte, 占1个字节.  ...Int16, 等于short, 占2个字节. -32768 32767   Int32, 等于int, 占4个字节. -2147483648 2147483647   Int64, 等于long

    3K20

    还分不清int(5)和int的区别?

    我觉得对于刚学习mysql的人来说,或者甚至工作了几年的人来说,对于int(5),这个5的含义说不出来的大有人在,下面我们就来解释一下。 int(5)中的5的意思是显示宽度,显示宽度又是什么意思呢?...在说这个5之前,先说ZEROFILL,如果没有ZEROFILL,那么5就没有任何意义,下面我们建一张表 CREATE TABLE `user` ( `id` int(5) UNSIGNED ZEROFILL...,no没有设置,我们看出又有一个UNSIGNED,这又是什么玩意,其实只要我们设置了ZEROFILL,那么UNSIGNED就自动设置了,UNSIGNED就是无符号位,意思就是不能带有符号位,说白了就是最小值为...由此我们可以看出,其实int(5) 和 int并没有什么区别,他们之间要有区别,还得建立在设置ZEROFILL的基础上,如果不设置ZEROFILL,那么两个没区别 不过你可能会疑惑了,既然使用了ZEROFILL...` 下面我们看一下mysql整型的种类和取值范围,有符号位的最小值为0,无符号位的最小值为负数,并且最小值的绝对值加上最大值等于有符号位的最大值,公式 |min| + max = UNSIGNED

    1.4K20

    你知道 int(1) 和 int(10) 的区别吗?

    CREATE TABLE `user` (  `id` int(1) unsigned NOT NULL AUTO_INCREMENT,   PRIMARY KEY (`id`)) ENGINE=InnoDB...后面的数字,不影响int本身支持的大小,int(1)、int(2)...int(10)没什么区别。...先看个例子: CREATE TABLE `user` (  `id` int(4) unsigned zerofill NOT NULL AUTO_INCREMENT,   PRIMARY KEY (`...而且对于0001这种,底层存储的还是1,只是在展示的会补0。 总结 int后面的数字不能表示字段的长度,int(num)一般加上zerofill,才有效果。...10年前毕业加入宇宙行,工资不高、也不算太忙,业余坚持研究技术和做自己想做的东西。4年后离开国企,加入永辉互联网板块的创业团队,从开发、到架构、到合伙人。

    49910

    unsigned int的世界不简单

    在C和C++的世界中,还有一种类型,叫做无符号数据,修饰符位unsigned,比如今天要说的unsigned int。引入特殊的类型,一方面带来了好处,一方面也留下了隐患。...这种方法对于标准的算术运算来说并无多大差异,但是对于像小于“和大于“>”这样的运算就可能产生非直观的结果。...这就得从整型数据在计算机中的表示和C语言对待强制类型转换的方式说起。 我们知道,整数在计算机中通常是以补码的形式存在的,而-1的补码(用4个字节储存)为1111,1111,1111,1111。...而C语言对于强制类型转换是怎么处理的呢?对大多数C语言的实现,处理同样字长的有符号数和无符号数之间的相互转换的一般规则是:数值可能会改变,但是位模式不变。...也就是说,将unsigned int强制类型转换成int,或将int转换成unsigned int底层的位表示保持不变。

    93410

    uint和int的区别_int32和uint32

    注意: go语言中的int的大小是和操作系统位数相关的; 如果是32位操作系统,int类型的大小就是4字节; 如果是64位操作系统,int类型的大小就是8个字节 1、测试不同int类型占用字节数大小...) { fmt.Println("不同int类型占用的字节数大小:") var i1 int = 1 var i2 int8 = 2 var i3 int16 = 3 var i4...: 8 1.2、测试无符号int类型 func TestUIntSize(t *testing.T) { fmt.Println("不同无符号int类型占用的字节数大小...类型的取值范围 2.1、测试有符号int情况 func TestIntRange(t *testing.T) { // 不同int类型的取值范围 fmt.Println..., math.MaxInt64) fmt.Println() } 测试结果: 不同int类型的取值范围: int8: -128 ~ 127 int16: -32768 ~ 32767 int32: -

    1.5K20

    你对MySQL的int(11)真的了解吗?

    你对MySQL的int(11)真的了解吗? 最近在网上看到一篇关于int(3)和int(11)区别的帖子,我第一反应这不就是它们之间主要涉及存储整型数据时所需的位数,即3位和11位的差异。...mysql-int.jpg MYSQL int 数据存储范围 首先,需要明确的是,int(3)和int(11)都是表示整数类型,而不是定义整数的存储长度。...显示宽度 int(3)和int(11) 区别在于显示宽度的影响。当我们定义一个字段为int(3)时,这个数字表示的是在使用ZEROFILL填充字符时的显示宽度,而不是实际存储的整数位数。..._20240127224711.jpg 我们打开表的DDl,就可以看到,我们设置ZEROFILL的时候他会自动设置为unsigned(无符号) ZEROFILL只在整数类型上有效,对于其他数据类型(如浮点数...总结 在数据库设计中,INT(3)和INT(11)的区别主要在于它们控制输出时的显示宽度。实际的存储大小是相同的,都占用4个字节。

    34310

    聊聊面试-int和Integer的区别

    ,把常见的面试问题总结一下,今天想站在面试官的角度去和大家聊聊一些面试的基础题目,以及尽可能指导大家如何给出一个能让面试官满意的答复 基本回答 int 是 8 个基本数据类型(boolean, byte...应当避免无意的使用拆装箱,自动拆/装箱实际上是 Java 一种编译期的优化(技巧),算是一种语法糖,只是 Java 在编译期帮你自动转化,最终生成的字节码还是和你自己转换是一样的,无意的创建十万个对象对于程序的内存开销和处理速度来说是巨大的代价...,这道看似简单的题目,其实可以深挖的点还有很多,进一步考察你的基本功是否扎实,例如: 线程安全的 Integer (考察你对 java.util.concurrent 并发包的理解) 基本数据类型和引用类型的局限...(考察你对 Java 泛型的理解) 对象在内存中的结构(对象头 Header,实例数据 Instance Data,对齐填充 Padding) int 和 Integer 的区别,这算是典型高频面试题之一...,也是考察候选人基本功的题目之一,如果你基本功扎实,那么这基本算是一道送分题,目前我了解的大多数大厂和重视技术的公司都是非常重视候选人的基本功,基础决定你的上限在哪里,所以这里我也建议大家不要花太多精力在框架的使用和工具的安装配置上

    45910

    char arr和int arr的区别

    在C语言中,`char arr` 和 `int arr` 的区别主要在于它们所存储的数据类型和所占用的内存空间。 1....`int arr`:这是一个整数数组,`arr` 中的每个元素都是 `int` 类型,用于存储整数数据。`int` 类型用于存储整数,它的大小通常是4个字节(32位),但这也可能因编译器和平台而异。...例如,`char arr[10]` 将占用10个字节的内存。     `int arr`:由于 `int` 类型通常是4个字节,`arr` 的内存占用将是元素数量的4倍。...例如,`int arr[10]` 将占用40个字节的内存。    ...对于 `int arr`,你会使用数组索引和循环来访问和修改元素,或者使用数学函数来处理整数。在编程时,你应该根据你的需求选择合适的数据类型来声明数组。

    10910
    领券