mysql中的int类型对应于java中的Long类型

bug日记

  • 今天在写项目的时候碰到了就顺便记录一下,事情的经过是这样的↓
    在这里插入图片描述

  • 在数据库查询完后映射到po类的时候报了错

  • 娃子还小不懂事,屁颠屁颠跑回去看po类、数据字段、mapper.xml,大眼瞪小眼看了半天没看出来啥问题。
    在这里插入图片描述
    在这里插入图片描述

  • 没啥问题啊,于是我一顿debug找错,发现了自己mybatis框架里面这么一段代码在这里插入图片描述

  • 这一段是将数据库中表一行记录中的列映射成一个java对象,debug发现他是long类型的,我就觉得奇怪int对应的不应该是Integer类型的嘛??!!What?

  • 但是仔细想想其实也好像确实是这么回事
    在这里插入图片描述

  • 这里我勾选了无符号数,所以这里int的容量应该是0~2^32,但是总所周知,java中的int/Integer容量只有-2147483648~2147483647,所以我猜想基于这种情况,用Long来映射数据库中的int是合情合理的。

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值