gpt4 book ai didi

PHP - 如果其他列中的值重复,Mysql 在单列中添加值

转载 作者:行者123 更新时间:2023-11-30 00:37:38 25 4
gpt4 key购买 nike

我在编写以下代码时遇到了计算零件的问题。我从两个不同的表中提取数据,并使用内部联接将列链接在一​​起,效果很好。从 headkey 列获取数据时,可以有多个行具有相同的“键”来标识订单,然后我需要查看 Delivery 列来查看订单的值为 1 还是 -1。我需要能够将 1 和 -1 加在一起,因此如果订单有 1 和 -1,则等于 0,这意味着交货已取消。但如果订单有 1 + (-1) + 1,那么这将等于 1。在这种情况下,这就是交货。如果 headkey 列中的值匹配,是否可以在 delivery 列中添加值?我正在考虑使用多维数组,但我不完全理解它们是否能够实现它们。

<?php

$TransactionSql = "
SELECT apcshead.Key
, apcshead.DateInvoiced
, apcshead.InvNum
, apcsitem.Headkey
, apcsitem.ItemID
, apcsitem.Quantity
, apcshead.CustomerCode
, customers.BillTo1
, customers.BillTo2
, customers.City
, customers.PostCode
FROM customers
INNER JOIN (apcshead INNER JOIN apcsitem ON apcshead.Key = apcsitem.Headkey)
ON customers.CustomerCode = apcshead.CustomerCode";


$rs=odbc_exec($conn,$TransactionSql);
while($row = odbc_fetch_array($rs))
{
$Key = odbc_result($rs,"Key");
$DateInvoiced = odbc_result($rs,"DateInvoiced");
$InvNum = odbc_result($rs,"InvNum");
$Headkey = odbc_result($rs,"Headkey");
$ItemID = odbc_result($rs,"ItemID");
$Quantity = odbc_result($rs,"Quantity");
$CustomerCode = odbc_result($rs,"CustomerCode");

$DateInvoiced = new DateTime($DateInvoiced);
$DateInvoiced_date = $DateInvoiced->format('m-d-Y');

$DeliverySql = "SELECT Quantity, HeadKey FROM apcsitem WHERE HeadKey=20008";

if ($DateInvoiced_date == $Today)
{
if ($ItemID == 'Delivery' xor $ItemID == 'DeliveryCharge')
{
echo '
<td class="td" valign="top">' . $Key . '</td>
<td class="td" valign="top">' . $DateInvoiced_date . '</td>
<td class="td" valign="top">' . $InvNum . '</td>
<td class="td" valign="top">' . $Headkey . '</td>
<td class="td" valign="top">' . $ItemID . '</td>
<td class="td" valign="top">' . $Quantity . '</td>
<td class="td" valign="top">' . $CustomerCode . '</td>
</tr> ';
}
}

}

?>

这是该表的快照。 Table Example

精简版

$TransactionSql = "SELECT * FROM apcsitem";

$rs=odbc_exec($conn,$TransactionSql);
while($row = odbc_fetch_array($rs))
{
$Key = odbc_result($rs,"HeadKey");
$ItemID = odbc_result($rs,"ItemID");
$Quantity = odbc_result($rs,"Quantity");

if ($ItemID == 'Delivery' xor $ItemID == 'DeliveryCharge')
{
echo '
<td class="td" valign="top">' . $Key . '</td>
<td class="td" valign="top">' . $ItemID . '</td>
<td class="td" valign="top">' . $Quantity . '</td>
</tr> ';
}
}

下面是一个由困惑的员工完成的真实交易示例:)

enter image description here

所以基本上我需要做的是如果第二列包含delivery或deliveryCharge来过滤掉它们。然后,如果它们中的任何一个具有重复的 HeadKey(第一列中的值),则仅为过滤后的值添加最后一列的值。又名,具有相同 HeadKey 的人。在上图中,他们有 Delivery 和 DeliveryCharge。他们添加了它们并取消了它们。如果您根据组 (Delivery) 添加最后一列,则结果为 0,如果您将最后一列与组 (DeliveryCharge) 添加,您也将得到 0。这实际上意味着毕竟没有交付!

最佳答案

不要尝试通过将业务逻辑更改为数学求和来进行优化。

类似于:

$delivered = $order["ready"] === "yes" && $order["charged"] === "yes";
$cancelled = $order["ready"] === "yes" && $order["cancelled"] === "yes";

更加清晰。

我会考虑使用 ENUM 作为 true/false 或 yes/no 字段。这更容易理解。您可以拥有任意数量的状态,因此您不需要不稳定的 -1

关于PHP - 如果其他列中的值重复,Mysql 在单列中添加值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22028182/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com