js的number类型超过最大值(9007199254740992)的解决办法

问题:点击修改无法展示信息,即修改时调用查询queryOne,以id(long)为值id=1480042498255640-00 ,在数据库中该id=148004249825564012,即错误的id

根本原因:

js的number类型的最大值(安全值)2的53次方,为9007199254740992,一个16位的数值,如果超过这个值,那么js会出现不精确的问题。

解决方法:

1.控制用户新建数据时id的长度。如果可以,那这个最简单方便。

2.后端用字符串类型与前端交互

将后端的long类型转为string类型再向前端传,如果向前端传的是VO集合,则每个VO都需要转类型,太过于繁琐

3.在userVO中加入一个字段

如果项目已经成型并且修改数据库会造成不可预料的问题那么可以在适用于VO对象中再增加一个String类型id映射字段

温馨提示:设计表字段时尽量合理评估id字段的增长或者用varchar类型。

参考自网络,侵权请联系删除775745736@qq.com

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值