mysql中signed是什么类型_mysql|unsigned 与 signed 类型

通过mysql的数值类型设置,控制数值的正负

1,如何使用

在mysql的编辑器中,可以直接定义 bigint(20) unsigned

20200503183825962246.png

2, 发挥的作用

20200503183826174169.png

一般默认定义的数据类型为signed(有符号类型),取值返回包含有负数范围,一般正负值的差依然等于无符号类型的范围的上限值。

当定义为unsigned(无符号类型)时, 取值范围仅为正数范围,下限值为0;

3,当设置为unsigned时候,报错BIGINT UNSIGNED value is out of range....如何解决

使用unsigned限制数值范围为正数的时候,如果执行相减操作产生负数;就会报错;解决方法

--需要添加四个计算值计算每日变化数据--dayConfirmed: 每日确诊--dayRecovered: 每日康复--dayDeaths: 每日死亡--dayExisting: 当日现存

selectn.id,

n.region_id,

n.region_parent_id,

n.recovered,

n.deaths,

n.day_date,

n.confirmed,

(cast(n.confirmed as signed) - cast(m.confirmed as signed)) asdayConfirmed,

(cast(n.recovered as signed) - cast(m.recovered as signed)) asdayRecovered,

(cast(n.deaths as signed) - cast(m.deaths as signed)) asdayDeaths,

(cast(n.confirmed as signed) - cast(n.recovered as signed) - cast(n.deaths as signed)) asdayExistingfrom region_data_total asnjoin region_data_total as m on date_sub(n.day_date, interval 1 day) =m.day_datewhere n.region_id = m.region_id and n.day_date = (select max(day_date) from region_data_total);

核心: 使用 cast(targetCol as signed) 将所有涉及到的unsigned字段先转化为signed类型后,再进行运算

相关内容补充:

MYSQL的数据类型(菜鸟教程):

https://www.runoob.com/mysql/mysql-data-types.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值