PostgreSQL 中的除法 (/) 不准确
在 PostgreSQL 中执行除法时,重要的是要考虑所涉及的数据类型以确保结果准确。在所描述的情况下,目标是确定要销售的软件数量以收回开发成本,整数除法可能会导致不正确的结果。
在提供的查询中,dev_cost 和 sell_cost 都是整数类型。整数除法将结果截断为零,这意味着 16000 除以 7500 得到 2,而不是预期的 3。
要获得准确的结果,至少有一个值必须转换为浮点型类型,例如浮点数或小数。或者,可以使用 ::decimal 语法将 dev_cost 显式隐式转换为小数。这会将除法强制转换为浮点运算,从而产生非截断除法。
考虑以下修改后的查询:
select dev_cost::decimal / sell_cost from software ;
或者,可以使用 ceil() 函数将结果四舍五入到最接近的整数:
select ceil(dev_cost::decimal / sell_cost) from software ;
通过利用这些技术,可以获得准确的除法结果,确保基于数据库查询的业务计算是合理的。
以上是如何避免 PostgreSQL 中整数除法不准确?的详细内容。更多信息请关注PHP中文网其他相关文章!