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

WBOY
發布: 2016-06-23 14:21:35
原創
951 人瀏覽過

最近做淘宝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吧

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板