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);

#查询数据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;

测试结果:

超出精度异常

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值