mysql有符号⽆符号整型_mysql创建表时的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,如果有符号位就+ -两边均分,如果没有就全给+。
精度
mysql 创建表时的 int 的有符号和⽆符号的区别
int 有符号测试
#创建⼀个有符号的int类型的abc的表create table bcd (a int,b int);#int类型不声明则默认为有符号
#插⼊数据insert into bcd values(1,2);
mysql创建表数据类型#查询数据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;
测试结果:
超出精度异常
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论