Maison  >  Article  >  développement back-end  >  E+14 超大整数的mysql存储问题

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

WBOY
WBOYoriginal
2016-06-23 14:21:35953parcourir

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

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn