使用 SQL 查询和 php while 循环创建 html table

Using SQL queries and php while loops to create an html table

我有 5 SQL 个查询。我想在 HTML 中显示 table 中的结果。现在,我嵌套了 while 循环来读取这些查询的结果。但是,结果 table 重复前 5 列的第一行(路线出现在所有查询中)。第 6 列是正确的。

这是我的 table 声明、连接到数据库后的查询和 while 循环:

<table style="width:100%">
    <tr>
       <th>Route</th>
       <th>Total Cost ($)</th> 
       <th>Utilization (%)</th>
       <th>Number Locations Serviced</th>
       <th>Total Time (Hrs)</th>
       <th>Cost per Item Delivered ($)</th>
    </tr>

    $query1 = "SELECT RouteID as Route, ROUND(SUM(CostTo), 2) as TotalCost FROM VehicleRoutes, ContractID WHERE ContractID.ContractID >= ALL(SELECT ContractID.ContractID FROM ContractID) AND ContractID.ContractID = VehicleRoutes.ContractID GROUP BY RouteID";

    $result1 = mysqli_query($conn, $query1);

    $query2 = "SELECT Items.RouteID as Route, ROUND((COUNT(*)/ContractID.TruckCapacity)*100, 3) as UtilizationPercentage FROM Items, ContractID WHERE Items.ContractID = ContractID.ContractID AND Items.RouteID != 'NA' AND ContractID.ContractID >= ALL(SELECT ContractID.ContractID FROM ContractID) GROUP BY Items.RouteID";

    $result2 = mysqli_query($conn, $query2);

    $query3 = "SELECT V.RouteID as Route, COUNT(V.LocationIDTo) as NumLocationsServiced FROM VehicleRoutes as V, ContractID WHERE ContractID.ContractID >= ALL(SELECT ContractID.ContractID FROM ContractID) AND V.LocationIDTo != 'Warehouse' AND V.ContractID = ContractID.ContractID GROUP BY V.RouteID";

    $result3 = mysqli_query($conn, $query3);

    $query4 = "SELECT V.RouteID as Route, ROUND(SUM(V.TravelTime + V.DeliveryTime), 3) as TotalTime FROM VehicleRoutes as V, ContractID WHERE ContractID.ContractID >= ALL(SELECT ContractID.ContractID FROM ContractID) AND ContractID.ContractID = V.ContractID GROUP BY V.RouteID";

    $result4 = mysqli_query($conn, $query4);

    $query5 = "SELECT  I.RouteID AS Route, ROUND(SUM(V.CostTo) / COUNT(I.ItemID) , 2) AS CostPerItemDelivered FROM Items AS I, VehicleRoutes AS V, ContractID WHERE  ContractID.ContractID >= ALL(SELECT ContractID.ContractID FROM  ContractID) AND  I.RouteID !=  'NA' AND  I.RouteID =  V.RouteID AND  I.ContractID =  ContractID.ContractID AND  V.ContractID =  I.ContractID GROUP BY  I.RouteID";

    $result5 = mysqli_query($conn, $query5);

    while($col1 = mysqli_fetch_array($result1)){ 
        while($col2 = mysqli_fetch_array($result2)){
        while($col3 = mysqli_fetch_array($result3)){
            while($col4 = mysqli_fetch_array($result4)){
                while($col5 = mysqli_fetch_array($result5)){
                echo "<tr><td>".$col1["Route"]."</td><td>".$col1["TotalCost"]."</td><td>".$col2["UtilizationPercentage"]."</td><td>".$col3["NumLocationsServiced"]."</td><td>".$col4["TotalTime"]."</td><td>".$col5["CostPerItemDelivered"]."</td></tr>";
                    }
                }
            }
        }
    }

这是我得到的结果: I checked the results individually before putting them in the loops, so I know they are correct. I'm just not sure why the first row is repeating itself for everything but "Cost/Item Delivered."

您需要做的是数据映射,将源数据(从SQL)转换为目标数据(table数据)。我已经更新了 while-loop 部分,这是如何转换数据的示例之一:

$targetData = array();

function addData(&$targetData, $routeId, $dataKey, $dataValue) {
    if (!isset($targetData[$routeId])) $targetData[$routeId] = array();
    $targetData[$routeId][$dataKey] = $dataValue;
}

while($col1 = mysqli_fetch_array($result1)) {
    addData($targetData, $col1['Route'], 'TotalCost', $col1['TotalCost']);
}

while($col2 = mysqli_fetch_array($result2)) {
    addData($targetData, $col2['Route'], 'UtilizationPercentage', $col2['UtilizationPercentage']);
}

while($col3 = mysqli_fetch_array($result3)) {
    addData($targetData, $col3['Route'], 'NumLocationsServiced', $col3['NumLocationsServiced']);
}

while($col4 = mysqli_fetch_array($result4)) {
    addData($targetData, $col4['Route'], 'TotalTime', $col4['TotalTime']);
}

while($col5 = mysqli_fetch_array($result5)) {
    addData($targetData, $col5['Route'], 'CostPerItemDelivered', $col5['CostPerItemDelivered']);
}

foreach ($targetData as $routeId => $data) {

    echo '<tr>' . 
            '<td>' . $routeId . '</td>' .
            '<td>' . (isset($data['TotalCost']) ? $data['TotalCost'] : '&nbsp;') . '</td>' .
            '<td>' . (isset($data['UtilizationPercentage']) ? $data['UtilizationPercentage'] : '&nbsp;') . '</td>' .
            '<td>' . (isset($data['NumLocationsServiced']) ? $data['NumLocationsServiced'] : '&nbsp;') . '</td>' .
            '<td>' . (isset($data['TotalTime']) ? $data['TotalTime'] : '&nbsp;') . '</td>' .
            '<td>' . (isset($data['CostPerItemDelivered']) ? $data['CostPerItemDelivered'] : '&nbsp;') . '</td>' .
        '</tr>';

}