首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在关系数据库中存储多达78位数字

在关系数据库中存储多达78位数字
EN

Stack Overflow用户
提问于 2022-06-30 09:41:20
回答 2查看 161关注 0票数 0

SQL服务器这样的数据库允许存储多达38位数字。

对于某些用例,如加密货币数字存储,此金额是不够的。以身作则。ETH的值声明为uint256。这代表高达78位数。

我所看到的避免舍入和丢失准确性的唯一解决方案是将加密货币/令牌的数量存储为字符串。

这是非常不切实际的,因为您不能像SUM().那样在SQL中操作。

必须有其他的解决办法。

类似的问题被问到存储ETH精度 密码货币十元

EN

回答 2

Stack Overflow用户

发布于 2022-07-01 12:29:51

两解

  • PostgreSQL愉快地存储多达78位数字。请切换到更好的数据库。PostgreSQL离MSSQL不远。因此,您对“数据库”的评论是不正确的,它只是一些数据库。
  • 将数据存储为32字节、二进制blobs、BINARY(32),并在应用程序级别将数字转换为小数。这比字符串有效得多。但是,您仍然需要在应用程序级别执行SUM(),或者在数据库级别执行脚本。切换到更好的数据库要容易得多。
票数 1
EN

Stack Overflow用户

发布于 2022-07-01 12:16:07

我想出的一个解决方案是,将数字除以不同的列,然后对每一列进行必要的操作。稍后总结所有的列。

这个解决方案并不完美,因为数据库无论如何都不会存储78位数字,,但是使更接近真值

将数字存储在字符串中,然后将字符串转换为数字格式是不理想的,我将失去每行十进制的准确性。

没有一个解决方案会给我真正准确的数字,但通过除以列中的数字,我失去了较低的准确性。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72813558

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档