php mySql 更新集将小数向下舍入

标签 php mysql

我有一个数据库,其中有一列名为“价格”

类型为 DECIMAL,长度/值设置为 15,4,默认值为 0.0000

运行以下命令时:

            $x=1;
            $table[$x]['MSRP'] = 10.5000;
            $table[$x]['Materialid'] = 1744000004;

            $mysql['updateprice'] = $mysql['conn']->prepare("UPDATE oc_product SET price = ? WHERE sku = ?");
            $mysql['updateprice']->bind_param("ii", $table[$x]['MSRP'],$table[$x]['Materialid']); //s=string i=integer d=double b=blob
            $mysql['updateprice']->execute();

保存的数字为“10.000”

无论我使用哪个号码,都会发生这种情况。

例如,

12.7 变成 12.0000

12.7000 变为 12.0000

13.1 变为 13.0000

13.1000 变为 13.0000

使用phpmyadmin插入号码时,没有任何问题。

我尝试过使用 floatval 但没有任何运气。

如何在不修改数据库结构的情况下完全按照给定的方式进行保存?

最佳答案

您将变量绑定(bind)为整数。您需要将它们绑定(bind)为 double ,正如您在注释代码中所指出的

$mysql['updateprice']->bind_param("di", $table[$x]['MSRP'],$table[$x]['Materialid']); 
//s=string i=integer d=double b=blob

关于php mySql 更新集将小数向下舍入,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40026822/

相关文章:

php - MySQL 查询 : search keyword like %

php - MySQL计数问题

Windows 中的 PHP - exec 输出数组字符编码

php - 如何在印度标准时间中插入日期时间并在检索格式日期时间后仅在 php 中插入日期时间?

php - 将 Doctrine native 查询映射到无实体模型类

mysql - MySQL 中两个表的总体唯一计数

MySQL查询以查找部分重复项

php - Laravel Gmail 不工作, "Username and Password not accepted. Learn more..."

mysql - 在 MySQL 中查找包含给定值的列

php - 获取特定订单