V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
zzzkkk
V2EX  ›  PHP

symfony form money type 为什么存到数据库 是价格乘以 100?

  •  
  •   zzzkkk · 2021-12-29 12:56:59 +08:00 · 1721 次点击
    这是一个创建于 820 天前的主题,其中的信息可能已经有所发展或是发生改变。

    symfony form money type 为什么存到数据库 是价格乘以 100 ? 是 doctrine 缘故吗?

    在数据库里的类型是 decimal(12,2)

    页面里输入 2.22 form->getData() 得到 222

    6 条回复    2021-12-30 15:12:32 +08:00
    cpstar
        1
    cpstar  
       2021-12-29 13:00:49 +08:00
    难道不去数据库里看一下存的是 2.22 还是 222 么?如果是 222 ,那就是 getData 要做 cast ,如果是 2.22 ,还是 getData 做了错误的 cast 。
    getData:所以就是怪我喽ㄟ(≧◇≦)ㄏ。
    xumng123
        2
    xumng123  
       2021-12-29 16:00:32 +08:00 via iPhone   ❤️ 1
    钱不能用浮点数,必须化成整数
    fkdog
        3
    fkdog  
       2021-12-29 16:20:22 +08:00
    浮点数做运算会出误差的。
    0.3+0.3+0.3 算出来的结果是 0.89999999999.
    强行四舍五入精度不够的话,容易产生误差,假设一笔误差 0.00001 ,一天上百万笔交易金额产生的误差就会以千万为单位。。一年下来就是好几百万了。
    lap510200
        4
    lap510200  
       2021-12-29 16:41:43 +08:00
    @xumng123 数据库字段用的 decimal(12,2 )可以存浮点数,计算用高精计算,不一定非要存分
    TonyG
        5
    TonyG  
       2021-12-29 17:25:50 +08:00
    老派规避浮点计算问题的做法,但很有效
    zzzkkk
        6
    zzzkkk  
    OP
       2021-12-30 15:12:32 +08:00
    @fkdog

    特地去数据库测试了下 原来的 order_total 是 decimal(12,2)
    新增一个字段 total decimal(12,2)
    update orders set total = order_total *100;

    结果 sum 两个字段出来正好一样 无非是总数*100
    +------------------+
    | SUM(order_total) |
    +------------------+
    | 48461619.87020 |
    +------------------+

    +---------------+
    | SUM(total) |
    +---------------+
    | 4846161987.02 |
    +---------------+


    259585 行数据
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1026 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 22:30 · PVG 06:30 · LAX 15:30 · JFK 18:30
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.