我正在尝试编写 PL/SQL 来获取如果您购买一定数量的物品需要支付多少费用。如果您购买 3 件商品,您将免费获得 1 件。

因此,每购买 4 件商品,其中一件是免费的。这意味着如果“购买”了 4 件商品,我会为 3 件商品付款。如果获得 10 件物品,则应支付 8 件费用,2 件免费。

p-b     v_p
***     ***
1        1                  = 1
2        2                  = 2
3        3                  = 3
4        3(1)               = 3
5        3(1) + 1           = 4
6        3(1) + 2           = 5
7        3(1) + 3           = 6
8        3(1) + 3(1)        = 6
9        3(1) + 3(1) + 1    = 7
10       3(1) + 3(1) + 2    = 8
11       3(1) + 3(1) + 3    = 9
12       3(1) + 3(1) + 3(1) = 9

我有
trunc(p-b / 3 * 2.4);

但我的值(value)观不一致。

有时它与
trunc(p-b / 3 * 2.25);

我的公式做错了吗?我应该使用 trunc 或 mod。

最佳答案

计算付费/免费内容的数量:

DECLARE
        nAmount NUMBER := '10';
        nPay NUMBER;
        nFree NUMBER;
BEGIN
        nPay := nAmount - TRUNC(nAmount / 4);
        nFree := TRUNC(nAmount / 4);
        DBMS_OUTPUT.PUT_LINE('Pay: ' || nPay);
        DBMS_OUTPUT.PUT_LINE('Free: ' || nFree);
END;
/

关于sql - 买3送1的公式,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/46521608/

10-10 19:06