随笔 - 493  文章 - 0  评论 - 97  阅读 - 239万

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

From: http://www.cnblogs.com/xiaochaohuashengmi/archive/2011/08/25/2153016.html

 

mysql int(1) tinyint(1)有什么区别?
我指定了字段长度,类型还有意义吗?
 
Reply:
mysql 中int(1)和tinyint(1)中的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>

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

============================================================
mysql   中   真,假   这样的数据应该用什么数据类型?
reply:tinyint(1)
 
可参考: http://database.51cto.com/art/201203/323863.htm
 
 
 
posted on   清清飞扬  阅读(674)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET10 - 预览版1新功能体验(一)
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示