欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

E+14 超大整数的mysql存储问题

程序员文章站 2024-04-03 14:33:46
...
最近做淘宝api的开发,遇到淘宝的订单号;是一个15位的整数,从淘宝数据库取得的是用科学计数法表示的:3.09086009604219E+14,以前遇到11位以上的数字,都是做成varchar;但是后面用到淘宝api又必须明确使用整型订单号,请问一下这样一个超大的整数是怎么存储到mysql的啊,用float吗??????
跪求跪求啊。。。。。。。

回复讨论(解决方案)

bigint

mysql数据类型bigint,传入数据库前是否需要处理数据呢。。还是直接传入3.09086009604219E+14???E+14这个字符串能够被正常识别吗???? bigint

肯定是不行的了,科学计数法已丢失了精度
只能以字符串保存

我不知道你是如何读的,至少库中是不可能保存成科学计数法的

那只是你读取之后输出显示是这个样子,设计好你的数据库字段类型 插入即可。

谢谢各位大神,原来淘宝订单编号是字符串,不是整型数字。。我看文档上订单编号类型写的number,就自以为是整型,测试了半天错误才去看文档上写的number指提数字串。。坑爹啊。。
各位接分。。

$tid = sprintf("%.0f",$trade->tid);

我刚做,这样OK。大家COPY吧