php中的FIFO计算(mysql)

时间:2016-01-13 19:29:38

标签: php mysql

我有两个数据表stock_incomes,stock_outcomes和stock_outcomes_fifo(我插入预先计算的数据):

stock_incomes(存储剩余数据)

id| Levtv
-----------
7 | 100
8 | 250
9 | 350

stock_outcomes(这是重点)

id| Quantity
--------------
1 |  150*

我没有问题当stock_outcome.Quantity小于100(来自stock_incomes的最小值(Id),请参阅下面的代码)但我不知道要编写什么代码如果结果> 100则我可以得到计算。在我的例子中,我使用了150,我希望在下表中获得数据:

stock_outcomes_fifo(我希望从前两张表中插入预先计算的数据)

id| IncomeId| OutcomeId| OutcomePart| Leftv
---------------------------------------------
1 |    7    |     1    |     100    |  0
2 |    8    |     1    |      50    |  200

这是我的代码里面有问题(参见代码的最后一部分):

<?php
include_once("config.inc.php");
include_once("db.class.php");

// stock_outcomes
$db = new db($host, $database, $user, $passwd);
$sql = "SELECT * FROM stock_outcomes WHERE Id = '1'";
$mas = $db->get_array($sql);

if($mas) {
    foreach ($mas as $k => $v) {
           $OutcomeId = $mas[$k]['Id'];
           $OutcomeQuantity = $mas[$k]['Quantity'];
    }
}

// stock_incomes
$sql = "select * from stock_incomes where Id = (select min(Id) from stock_incomes where Leftv > 0)";
$mas = $db->get_array($sql);

if($mas) {
    foreach ($mas as $k => $v) {
        $IncomeId = $mas[$k]['Id'];
        $IncomeLeftv = $mas[$k]['Leftv'];
    }
}

// insert into stock_outcomes_fifo

if ($OutcomeQuantity <= $IncomeLeftv) { 
    $OutcomePart = $OutcomeQuantity;
    $FifoLeftv = $IncomeLeftv - $OutcomeQuantity;

    mysql_query("INSERT INTO `stock_outcomes_fifo` (IncomeId,OutcomeId,OutcomePart,Leftv) VALUES ($IncomeId, $OutcomeId, $OutcomePart, $FifoLeftv)");
}

if ($OutcomeQuantity > $IncomeLeftv) {
    // I have no idea what php function to use in this case... please give me direction, thank you...
}
?>

1 个答案:

答案 0 :(得分:0)

问题已经解决,这是最终的工作代码,以防有人可能需要它:

<?php
include_once("config.inc.php");
include_once("db.class.php");

// stock_outcomes
$db = new db($host, $database, $user, $passwd);
$sql = "SELECT * FROM stock_outcomes WHERE Id = '1'";
$mas = $db->get_array($sql);

if($mas){
    foreach ($mas as $k=>$v) {
           $OutcomeId=$mas[$k]['Id'];
           $OutcomeBarCode=$mas[$k]['BarCode'];
           $OutcomeQuantity=$mas[$k]['Quantity']; 
    }
}

/* - Start code */
if ($OutcomeQuantity > 0) {
$sql = "select * from stock_incomes where Leftv > 0 order by id asc";
$mas = $db->get_array($sql);

if ($mas) {
    //filing stock_outcomes_fifo 
        foreach ($mas as $k=>$v) {
        $IncomeId = $mas[$k]['Id'];
        $IncomeQuantity = $mas[$k]['Quantity'];
        $IncomeUnitPrice = $mas[$k]['UnitPrice'];
        $IncomeLeftv = $mas[$k]['Leftv'];

        $OutcomePart = min($OutcomeQuantity, $IncomeLeftv);
        $FifoLeftv = $IncomeLeftv - $OutcomePart; 
        $FifoCost = $IncomeUnitPrice * $OutcomePart;

        mysql_query("INSERT INTO `stock_outcomes_fifo` (BarCode,IncomeId,OutcomeId,OutcomePart,UnitPrice,Leftv,Cost) VALUES ($OutcomeBarCode, $IncomeId, $OutcomeId, $OutcomePart, $IncomeUnitPrice, $FifoLeftv, $FifoCost)");          
        mysql_query("UPDATE `stock_incomes` SET Leftv = ".$FifoLeftv." WHERE Id = ".$IncomeId);

        $OutcomeQuantity -= $OutcomePart;
        if ($OutcomeQuantity <= 0) break;
    }

    $OutcomeCostQuery = "select sum(Cost) as summ from stock_outcomes_fifo where OutcomeId = ".$OutcomeId."";
    $OutcomeCost = mysql_query($OutcomeCostQuery);
    $OutcomeCostResult = mysql_fetch_array($OutcomeCost);        
    mysql_query("UPDATE `stock_outcomes` SET Cost = ".$OutcomeCostResult["summ"]." WHERE Id = ".$OutcomeId."");
}
} /* - Finish code */

?>