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