如果在建表时不指定字段int类型的长度时,系统则默认生成长度为11的字段。11也是int类型的最大长度,其中第一位表示符号+或者-,后面十位表示数字。
如果指定了长度,该字段其实也是长度为11的字段,因为只要是int类型,系统都分配了长度11位。
所以,当我们在用mysql数据库建表时如果有字段为int类型则不用指定长度了。
int最大长度是11位。在32位的机器下,int的范围是 - 2 ^ 31 ~2 ^ 31 - 1 也就是:[-2147483648, 2147483647];在16位的机器下,int的范围为 -2 ^ 15 ~ 2 ^ 15-1。
也就是 :[-32768,32767];整型变量int的范围与计算机的字长有关,int 的长度是一个计算机字长。
int类型允许存储的字节数是4个字节,换算出int UNSIGNED(无符号)类型的能存储的最小值为0,最大值为4294967295(即4B=32b, 最大值即为32个1组成)。
扩展资料:
int型字长问题:
long int型至少应该和int型一样长,而int型至少应该和short int一样长。
1、C/C++规定int字长和机器字长相同;
2、 *** 作系统字长和机器字长未必一致;
3、编译器根据 *** 作系统字长来定义int字长;
在一些没有 *** 作系统的嵌入式计算机系统上,int的长度与处理器字长一致;有 *** 作系统时, *** 作系统的字长与处理器的字长不一定一致,此时编译器根据 *** 作系统的字长来定义int字长:“比如在64位机器上运行DOS16系统。
那么所有for dos16的C/C++编译器中int都是16位的;在64位机器上运行win32系统,那么所有for win32的C/C++编译器中int都是32位的”。(CPU的“字长”是指其一条指令/一次运算可以处理的数据的最大宽度。
对于整型的数值范围,每个编译器里面都有一个标准头文件:limits.h,这个头文件定义了一些宏,这些宏表示该编译器使用的所有数据类型的范围,编程过程中使用这些宏就行了。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)