php和mysql中增值税的小数精度

时间:2013-01-22 15:50:00

标签: php mysql floating

我有一个问题,我无法自己解决,我想我可以被推到这里,以获得最好的精度计算PHP和MySQL的增值税价格。

例如:

I have the gross price = 1199
The TAX Amount is      = 24
to extract the vat     = 1199 / 1.24 = 966.93548387096 round(966.93548387096,2) = 966.94
ok
now this value will be saved in mysql with decimal 12,2

Now, if you add the vat = 966.94 * 24 / 100 = 232.0656 round(232.0656,2) = 232.07
Final                   = 966.94 + 232.07 = 1199.01

我的问题是,如何在不浮动的情况下获得1199?

任何帮助都是吝啬的。!

更新:

保存在数据库中的值是966.94,从那里应用税额。

当我在数据库中引入价格时,一个选项可以保存4位小数值,但为此我需要覆盖一个数组来取代该列并取出大桶。

像:

$arrResult = array();
            $handle = fopen("uploads/csv/".$csv, "r");
            if( $handle ) {
            while (($row = fgetcsv($handle, 1000, ",")) !== FALSE) {
            $arrResult[] = $row;
            }
            fclose($handle);
            }
            $titles = array_shift($arrResult);
            // need to take out the price and apply price / 1.24 and save the value as 4 decimal in mysql
            $keys = array('code', 'price');

            $final = array();

                    foreach ( $arrResult as $key => $value ) {
                                $final[] = array_combine($keys, $value);
                    }

2 个答案:

答案 0 :(得分:0)

您可以使用MySQL的CAST()功能。

示例

mysql> select 1199.01 as floating, cast( 1199.01 as signed ) as non_floating;
+----------+--------------+
| floating | non_floating |
+----------+--------------+
|  1199.01 |         1199 |
+----------+--------------+
1 row in set (0.00 sec)

请参阅
Type Casting in MySQL

CAST can be used to convert to the following types:

 1. BINARY[(N)]
 2. CHAR[(N)] DATE
 3. DATETIME DECI
 4. MAL[(M[,D])]
 5. SIGNED [INTEGER]
 6. TIME
 7. UNSIGNED [INTEGER]

答案 1 :(得分:0)

这是一个古老的问题,但是绝对不要将浮点数用作货币金额。

这是因为浮点数会给计算带来很多麻烦(如果您在网络上搜索,则会发现大量说明该问题的文章)。

因此,解决方案是使用类似https://github.com/moneyphp/money的值对象

然后,您将以最小单位为简单整数的基本金额保存在数据库中。

这意味着100,00欧元代表10000分。

该库仅对整数进行操作(并在内部使用字符串),非常精确!