教程集 www.jiaochengji.com
教程集 >  数据库  >  mysql  >  正文 mysql int(1) 与 tinyint(1) 区别

mysql int(1) 与 tinyint(1) 区别

发布时间:2016-04-07   编辑:jiaochengji.com
本文介绍了mysql数据库中int(1) 与 tinyint(1)的区别,mysql 中int(1)和tinyint(1)中的1只是指定显示长度,并不表示存储长度。

问题:
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)

您可能感兴趣的文章:
mysql int(1) 与 tinyint(1) 区别
MySQL数据类型BOOL/BOOLEAN与TINYINT的测试详解
mysql 数据库unsigned的用法
mysql字段、主键、索引等的创建与修改命令
MySQL数据类型之集合类型和枚举类型的用法
mysql tinyint 取值范围浅析
mysql中int(1)和int(11)区别详解
mysql表删除重复记录方法与效率对比分析
高性能mysql(第二版)学习笔记之架构优化和索引
mysql alter语句用法举例

关键词: 字段类型   
[关闭]
~ ~