int(4)和int(5)是否有区别?

本文深入解析了MySQL中整数类型关键字及其显示宽度的概念,包括INT类型如何通过括号指定显示宽度,结合ZEROFILL属性的作用,以及UNSIGNED属性的使用。同时,解释了显示宽度与存储空间、范围之间的关系,提供了实例演示。

MySQL类型关键字后面的括号内指定整数值的显示宽度(例如,INT(4))。该可选显示宽度规定用于显示宽度小于指定的列宽度的值时从左侧填满宽度。显示宽度并不限制可以在列内保存的值的范围,也不限制超过列的指定宽度的值的显示。


mysql> insert into t01 (uid) values (12),(123),(1234);
Query OK, 3 rows affected (0.01 sec)
Records: 3  Duplicates: 0  Warnings: 0
mysql> 


当结合可选扩展属性ZEROFILL使用时, 默认补充的空格用零代替。例如,对于声明为INT(3) ZEROFILL的列,值12检索为012。请注意如果在整数列保存超过显示宽度的一个值,当MySQL为复杂联接生成临时表时会遇到问题,因为在这些情况下MySQL相信数据适合原列宽度。

mysql> insert into t01 (id) values (12),(123),(1234); 
Query OK, 3 rows affected (0.01 sec)
Records: 3  Duplicates: 0  Warnings: 0
mysql> 


所有整数类型可以有一个可选(非标准)属性UNSIGNED。当你想要在列内只允许非负数和该列需要较大的上限数值范围时可以使用无符号值。如果设置了ZEROFILL扩展属性试,默认就有了无符号属性(UNSIGNED)


所以INT(4)与INT(5)后的括号中的字符表示显示宽度,整数列的显示宽度与MySQL需要用多少个字符来显示该列数值,与该整数需要的存储空间的大小都没有关系,INT类型的字段能存储的数据上限还是2147483647(有符号型)和4294967295(无符号型)。其实当我们在选择使用INT的类型的时候,不论是int(4)还是int(5),它在数据库里面存储的都是4个字节的长度。

总结,INT(M) ZEROFILL,加上ZEROFILL后M才表现出有点点效果,比如 INT(3) ZEROFILL,你插入到数据库里的是10,则实际插入为010,也就是在前面补充加了一个0.如果INT(3)和INT(10)不加ZEROFILL,则它们没有什么区别.M不是用来限制INT列内保存值的范围的.int(M)的最大值和最小值与UNSIGNED有关。

这是一个非常经典的 C 语言问题: > **`int *p` `int* p` 有区别吗?** --- ## ✅ 答案: **在 C 语言中,`int *p` `int* p` 没有本质区别。** 它们都声明了一个名为 `p` 的指针变量,指向一个 `int` 类型的数据。 --- ## 一、C语言的指针声明语法 C 语言中指针的声明语法是: ```c 类型名 *指针变量名; ``` 所以: ```c int *p; // p 是一个指向 int 的指针 int* p; // 同样,p 是一个指向 int 的指针 ``` 在 C 编译器看来,这两种写法是**完全等价的**。 --- ## 二、为什么会有两种写法? 这两种写法更多是**编码风格**上的不同: | 写法 | 风格说明 | |-------------|----------| | `int *p;` | 更强调 `*p` 是一个 `int` 类型的表达式(即:对 p 取内容是一个 int) | | `int* p;` | 更强调 `p` 是一个指向 `int` 的指针类型(类似 C++ 的风格) | --- ## 三、多个变量声明时的区别(关键点) 当**在同一行声明多个变量**时,区别就显现出来了: ### ✅ 正确写法(推荐): ```c int *a, *b; // a b 都是指向 int 的指针 ``` ### ❌ 容易误解的写法: ```c int* a, b; // a 是指向 int 的指针,b 是 int 类型! ``` 这里 `b` 不是指针,而是 `int` 类型变量,这可能会造成混淆。 --- ## 四、建议风格 为了清晰避免错误,推荐使用以下风格: ```c int *p; // p 是指向 int 的指针 int *a, *b; // a b 都是指针 ``` 或者在多变量声明时分开写: ```c int *a; int *b; ``` --- ## 五、与 C++ 的区别(补充) 在 C++ 中,虽然语法兼容 C,但更推荐使用 `int* p`,因为 C++ 中 `using T = int*; T a, b;` 会把 `a` `b` 都定义为指针。 但在 C 中,这种类型别名方式不常用,因此影响不大。 --- ## 六、总结 | 写法 | 含义 | 是否等价 | 说明 | |------------|------------------------------|----------|------| | `int *p` | p 是指向 int 的指针 | ✅ 是 | 推荐写法 | | `int* p` | p 是指向 int 的指针 | ✅ 是 | 更像 C++ 风格 | | `int* a, b`| a 是指针,b 是 int 类型 | ❌ 风险 | 易误解 | | `int *a, *b`| a b 都是指针 | ✅ 推荐 | 多变量时清晰 | --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值