dougai3418 2019-05-06 14:16
浏览 192

PHP MSSQL - Bigint返回float,精度损失

Using PHP 5.5 x64 on Ubuntu.

I am trying to fetch some data from an MSSQL database using mssql_query; there is a variety of data types in the columns fetched, and it appears that no matter what I try, bigints (usually of numeric length 19) always convert to a float with accuracy loss.

Instead of getting 1000000000000000010, I am sometimes getting 1000000000000000012 or 1000000000000000009 and so on.

So far, I have tried:

  • Changing precision with ini_set to 19 (it works as expected up to 16, 17 and above seems to have no effect)

  • Playing around with fetch_assoc and fetch_object

  • Using PDO (not sqlsrv)

  • Upgrading to PHP 7.2 and using PDO (not sqlsrv)

Changing PHP settings and installing packages is possible - changing the data type of the SQL Server unfortunately isn't. For performance reasons, I am avoiding the use of CONVERT, as I'm dealing with big data.

How can I avoid the accuracy loss of the last digit?

  • 写回答

0条回答 默认 最新

    报告相同问题?

    悬赏问题

    • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
    • ¥15 有了解d3和topogram.js库的吗?有偿请教
    • ¥100 任意维数的K均值聚类
    • ¥15 stamps做sbas-insar,时序沉降图怎么画
    • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
    • ¥15 关于#Java#的问题,如何解决?
    • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
    • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
    • ¥15 cmd cl 0x000007b
    • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line