我有一个数据库,它将产品成本存储为(DECIMAL) 9,2,并将其命名为cost列。
我创造了一个手推车控制器,它工作得很好。在确保购物车有产品之后,我循环遍历产品的内容,用给定的产品和数量计算总成本。
$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查询生成器中将所有成本相加?
提前谢谢。
发布于 2019-01-16 14:56:36
使用printf或$s = sprintf将数字转换为字符串:
printf("%.02f", 150.00);https://stackoverflow.com/questions/54219636
复制相似问题