永发信息网

mysql int 与 tinyint 有什么区别

答案:2  悬赏:60  手机版
解决时间 2021-02-10 14:33
  • 提问者网友:書生途
  • 2021-02-10 05:26
mysql int 与 tinyint 有什么区别
最佳答案
  • 五星知识达人网友:人類模型
  • 2021-02-10 06:45
mysql int与tinyint有什么区别?
我指定了字段长度,类型还有意义吗?
  Reply:
  mysql 中int和tinyint中的1只是指定显示长度,并不表示存储长度,只有字段指定zerofill是有用
如int(3),如果实际值是2,如果列指定了zerofill,查询结果就是002,左边用0来填充。  
  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>
全部回答
  • 1楼网友:西岸风
  • 2021-02-10 08:22
mysql int与tinyint有什么区别? 我指定了字段长度,类型还有意义吗? reply: mysql 中int和tinyint中的1只是指定显示长度,并不表示存储长度,只有字段指定zerofill是有用 如int(3),如果实际值是2,如果列指定了zerofill,查询结果就是002,左边...
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯