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