我有一个数据库,其中有一列名为“价格”
类型为 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/