首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如何在PHP中计算后保持小数位?

如何在PHP中计算后保持小数位?
EN

Stack Overflow用户
提问于 2019-01-16 14:50:53
回答 2查看 1.1K关注 0票数 2

我有一个数据库,它将产品成本存储为(DECIMAL) 9,2,并将其命名为cost列。

我创造了一个手推车控制器,它工作得很好。在确保购物车有产品之后,我循环遍历产品的内容,用给定的产品和数量计算总成本。

代码语言:javascript
复制
$total = 0;
foreach(session('cart') as $key => $product)
    $total = $total + (\DB::table('product_list')->where('id', $key)->get()->first()->cost * $product[0]['quantity']);

我遇到的问题是小数位被忽略了。如果成本是150.00,我有1数量,那么总数是150,没有小数点的两位。

我试过使用bcmul(),它是为十进制与数学的集成而设计的,但这给了我同样的输出。我也尝试过使用ROUND($total, 2)来获得最近的小数点2位,如果没有,那么.00也没有用,但这也不起作用。

是否可以确保在使用任何数学查询后保留这些小数位,或者是否可以在SQL查询生成器中将所有成本相加?

提前谢谢。

EN

Stack Overflow用户

发布于 2019-01-16 14:56:36

使用printf$s = sprintf将数字转换为字符串:

代码语言:javascript
复制
printf("%.02f", 150.00);
票数 1
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54219636

复制
相关文章

相似问题

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