mysql数据类型-int
int 的有符号和无符号的区别
有符号的int可以插入负值,无符号的int不可以插入负值
整型的每一种都分无符号(unsigned)和有符号(signed)两种类型(float和double总是带符号的),在默认情况下声明的整型变量都是有符号的类型(char有点特别),如果需声明无符号类型的话就需要在类型前加上unsigned。
无符号版本和有符号版本的区别就是无符号类型能保存2倍于有符号类型的正整数数据,比如16位系统中一个smallint能存储的数据的范围为-32768~32767,而unsigned能存储的数据范围则是0~65535。
由于在计算机中,整数是以补码形式存放的。根据最高位的不同,如果是1,有符号数的话就是负数;如果是无符号数,则都解释为正数。另外,unsigned若省略后一个关键字,大多数编译器都会认为是unsigned int。
简而言之就是由于Int型占4字节,也就是16位,2^16 = 65535,如果有符号位就+ -两边均分,如果没有就全给+。
int有符号测试
#创建一个有符号的int类型的abc的表create table bcd (a int,b int);#int类型不声明则默认为有符号
#插入数据insert into bcd values(1,2);
#查询数据select * frombcd;
#查询2-1:结果为1select b-