mysql int(1) tinyint(1)有什么区别?

meadking 2008-10-17 10:03:59
mysql int(1) tinyint(1)有什么区别?
我指定了字段长度,类型还有意义吗?
...全文
2677 3 打赏 收藏 转发到动态 举报
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
zty598416146 2011-06-01
  • 打赏
  • 举报
回复
tinyint 是真正的一个字节
iihero_ 2008-10-17
  • 打赏
  • 举报
回复
TINYINT[(M)] [UNSIGNED] [ZEROFILL]

A very small integer. The signed range is -128 to 127. The unsigned range is 0 to 255.

INT[(M)] [UNSIGNED] [ZEROFILL]

A normal-size integer. The signed range is -2147483648 to 2147483647. The unsigned range is 0 to 4294967295.


位数限制基本没有意义。

mysql> create table testint(id int(1), col2 tinyint(1));
Query OK, 0 rows affected (0.06 sec)

mysql> insert into testint values(256, 257);
Query OK, 1 row affected, 1 warning (0.03 sec)

mysql> select * from testint;
+------+------+
| id | col2 |
+------+------+
| 256 | 127 |
+------+------+
1 row in set (0.02 sec)

mysql> insert into testint values(336, 257);
Query OK, 1 row affected, 1 warning (0.02 sec)

mysql> select * from testint;
+------+------+
| id | col2 |
+------+------+
| 256 | 127 |
| 336 | 127 |
+------+------+
2 rows in set (0.00 sec)

mysql> insert into testint values(336, 255);
Query OK, 1 row affected, 1 warning (0.03 sec)

mysql> select * from testint;
+------+------+
| id | col2 |
+------+------+
| 256 | 127 |
| 336 | 127 |
| 336 | 127 |
+------+------+
3 rows in set (0.00 sec)

mysql>

关注一下上边的warning提示。。。。





denniswwh 2008-10-17
  • 打赏
  • 举报
回复
mysql 中int(1)和tinyint(1)中的1只是指定显示长度,并不表示存储长度,只有字段指定zerofill是有用
如int(3),如果实际值是2,如果列指定了zerofill,查询结果就是002,左边用0来填充。

56,679

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧