Php 删除列中的重复数据

Php 删除列中的重复数据,php,mysql,concatenation,distinct,Php,Mysql,Concatenation,Distinct,我目前正在开发一个订购系统,客户可以订购许多物品。我也有一个管理员,他/她可以看到当天的所有订单。管理员可以查看客户名称、应付总额、产品以及客户订购的产品数量 我目前正在使用我的查询查看此结果 Name | Payable | Product | Quantity Test | 165 | keychain | 3 Test | 165 | Tumbler | 1 Miguel | 525 | Keychain | 3 Miguel |

我目前正在开发一个订购系统,客户可以订购许多物品。我也有一个管理员,他/她可以看到当天的所有订单。管理员可以查看客户名称、应付总额、产品以及客户订购的产品数量

我目前正在使用我的查询查看此结果

 Name   | Payable | Product   | Quantity
 Test   |   165   | keychain  | 3
 Test   |   165   | Tumbler   | 1
 Miguel |   525   | Keychain  | 3
 Miguel |   525   | Magic Mug | 3
 Dandel |   1010  | keychain  | 3
 Dandel |   1010  | T-shirt   | 2
 Dandel |   1010  | Keychain  | 3
 Dandel |   1010  | Mug       | 5
 $result = mysql_query("
        SELECT reservation.firstname, reservation.lastname, reservation.payable, reservation.city, orders.product, orders.qty, reservation.date
        FROM orders
        INNER JOIN reservation
        ON orders.confirmation = reservation.confirmation 
        WHERE reservation.date = CURDATE() && reservation.city = '24th Floor'
        ");
    while($row = mysql_fetch_array($result))
        {
            echo '<tr>';
            echo '<td style="border: 1px solid black;">'.$row['firstname'].'</td>';
            echo '<td>'.$row['payable'].'</td>';
            echo '<td>'.$row['product'].'</td>';
            echo '<td>'.$row['qty'].'</td>';
            echo '</tr>';
        } 
这是我的问题

 Name   | Payable | Product   | Quantity
 Test   |   165   | keychain  | 3
 Test   |   165   | Tumbler   | 1
 Miguel |   525   | Keychain  | 3
 Miguel |   525   | Magic Mug | 3
 Dandel |   1010  | keychain  | 3
 Dandel |   1010  | T-shirt   | 2
 Dandel |   1010  | Keychain  | 3
 Dandel |   1010  | Mug       | 5
 $result = mysql_query("
        SELECT reservation.firstname, reservation.lastname, reservation.payable, reservation.city, orders.product, orders.qty, reservation.date
        FROM orders
        INNER JOIN reservation
        ON orders.confirmation = reservation.confirmation 
        WHERE reservation.date = CURDATE() && reservation.city = '24th Floor'
        ");
    while($row = mysql_fetch_array($result))
        {
            echo '<tr>';
            echo '<td style="border: 1px solid black;">'.$row['firstname'].'</td>';
            echo '<td>'.$row['payable'].'</td>';
            echo '<td>'.$row['product'].'</td>';
            echo '<td>'.$row['qty'].'</td>';
            echo '</tr>';
        } 

您可以在迭代时保持某种状态,以跟踪当前行是否为新名称/应付款:

$last_name_seen = NULL;

while ($row = mysql_fetch_array($result)) {
    $firstname = "";
    $payable = "";
    if ($last_name_seen === NULL || $row['firstname'] != $last_name_seen) {
        $last_name_seen = $row['firstname'];
        $firstname = $row['firstname'];
        $payable = $row['payable'];
    }
    echo '<tr>';
    echo '<td style="border: 1px solid black;">'.$firstname.'</td>';
    echo '<td>'.$payable.'</td>';
    echo '<td>'.$row['product'].'</td>';
    echo '<td>'.$row['qty'].'</td>';
    echo '</tr>';
}

正如上面的评论所建议的,如果你使用一个废弃的PHP API,你应该考虑升级到更现代的东西。但是,更改MySQL API后,上述循环中使用的逻辑不会有太大变化。

您必须为名称和应付列设置标志,并使用array\u column()、array\u unique()来获取唯一列值:

<?php

$result = array(array("Name"=>"Test","Payable"=>'165',"Product"=>"keychain","Quantity"=>3),array("Name"=>"Test","Payable"=>'165',"Product"=>"Tumbler","Quantity"=>1));

$name_arr = array_unique(array_column($result, 'Name'));
$payable_arr = array_unique(array_column($result, 'Payable'));

$name_flag = 0;
$pay_flag = 0;

echo "<table border='1'>";

for($i=0;$i<count($name_arr);$i++)
{

    for($j=0;$j<count($payable_arr);$j++)
    {
        foreach($result as $list)
        {
            if($list['Name'] == $name_arr[$i] && $list['Payable'] == $payable_arr[$j])
            {
                if($name_flag==0 && $pay_flag==0)
                {
                    echo "<tr>";
                    echo "<td>".$name_arr[$i]."</td>";
                    echo "<td>".$payable_arr[$j]."</td>";
                    echo "<td>".$list['Product']."</td>";
                    echo "<td>".$list['Quantity']."</td>";
                    echo "</tr>";
                }
                else
                {
                    echo "<tr>";
                    echo "<td>&nbsp;</td>";
                    echo "<td>&nbsp;</td>";
                    echo "<td>".$list['Product']."</td>";
                    echo "<td>".$list['Quantity']."</td>";
                    echo "<tr>";
                }
                $name_flag++;
                $pay_flag++;
            }
        }
    }
    $name_flag=0;
    $pay_flag=0;
}
echo "</table>";
?> 

不要使用不推荐使用且不安全的
mysql.*
-函数。自PHP5.5(2013年)起,它们就被弃用,并在PHP7(2015年)中被完全删除。改用MySQLi或PDO。如果有多个用户使用相同的名称,会是什么样子?你如何区分它们?有用户id吗?Tim先生,这个代码很有用。谢谢你的帮助。但我还有一个问题。@Benj如果你有一个小的后续问题,请随时发表评论。如果这是一个全新的问题,那么请稍后再问另一个问题。希望这次你能再次帮助我。非常感谢。先生@Tim我发布了一个新问题。希望这次你能再次帮助我。非常感谢。