Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/64.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Php 如何从Mysql计算数字_Php_Mysql - Fatal编程技术网

Php 如何从Mysql计算数字

Php 如何从Mysql计算数字,php,mysql,Php,Mysql,我在mysql中的“p_L”列有关于利润或亏损的数字,而“Status”列有状态——如果这些数字是正数或负数 说明:50利润=+50,30损失=-30 我试图计算这些数字以获得总利润/亏损,但有些东西不起作用。下面代码的输出是:+50-30+50-25-15 那么,如何计算p_L列?这样的事情可能吗 谢谢大家! 表看起来像这样: +-------+---------------+--------+-----------+ | Id | Date Added | P_L |

我在mysql中的“p_L”列有关于利润或亏损的数字,而“Status”列有状态——如果这些数字是正数或负数

说明:50利润=+50,30损失=-30

我试图计算这些数字以获得总利润/亏损,但有些东西不起作用。下面代码的输出是:+50-30+50-25-15

那么,如何计算p_L列?这样的事情可能吗

谢谢大家!

表看起来像这样:

+-------+---------------+--------+-----------+
|   Id  |   Date Added  |   P_L  |   Status  |
+-------+---------------+--------+-----------+
|   1   |   2017-12-2   |   50   |   Profit  |
|   2   |   2017-12-3   |   30   |   Loss    |
|   3   |   2017-12-4   |   50   |   Profit  |
|   4   |   2017-12-5   |   25   |   Loss    |
|   5   |   2017-12-6   |   15   |   Loss    |
+-------+---------------+--------+-----------+
我的一段PHP代码

.
.
.
while($row = mysqli_fetch_array($result))  {  

    $id = $row['id'];
    $date_added = $row['date_added'];
    $p_l = $row['p_l'];
    $status = $row['status'];

    if($status == 'Profit') {
      $number = "+ $p_l";

    } elseif($status == 'Loss') {
      $number = "- $p_l";

    } 

    $total =  $number . " ";
    echo "$total";

   }

把总数放在循环之外

创建一个从零开始的占位符/容器,然后根据实际值进行加减:

在以下代码的指导下,由于您没有提供表结构,因此将
p_l
列转换为its

$total = 0; # placeholder
while($row = mysqli_fetch_array($result))  {  

    $id = $row['id'];
    $date_added = $row['date_added'];
    $p_l = $row['p_l'];
    $status = $row['status'];

    $number = floatval($p_l);

    if($status == 'Profit') {
      $total = $total + $number;

    } elseif ($status == 'Loss') {
      $total = $total - $number;
    } 

}
echo "$total";

您可以对MySQL查询中的p_L列求和:


乘以-1
是一种常见的方法。要获得进一步的帮助,请参阅您应该将损益分为两列,以便可以更简单地求和。现在仍然可以直接从MySQL而不是PHP中获得结果。注意:
mysqli
的面向对象接口明显不那么冗长,使代码更易于阅读和审核,并且不容易与过时的
MySQL\u query
接口混淆。在你对程序性风格投入太多之前,值得换一种。示例:
$db=new mysqli(…)
$db->prepare(“…”)
过程接口是PHP 4时代的产物,当时引入了
mysqli
API,不应在新代码中使用。@Wolf Ohhhh是的!谢谢:)
SELECT SUM(IF(Status = 'Profit', P_L, -1 * P_L)) AS profit_and_loss FROM tableName;