Group Query Results in PHP

后端 未结 2 1273
独厮守ぢ
独厮守ぢ 2021-01-23 10:20

I am using the following query to populate a table:

$result = mysql_query(\"SELECT vendor, part_number, machine, Sum(q_received) AS received, Sum(q_rejected) AS          


        
2条回答
  •  一个人的身影
    2021-01-23 10:52

    During each loop you have to decide if it is time to draw the heading--you're going to list a new vendor. If it isn't a new vendor, you're still listing parts for the one you drew the last heading for, so you don't want the heading or to end the table.

    $current_vendor = false;
    while($row = mysql_fetch_array($result)) {
        // listing a new vendor? Output the heading, start the table
        if ($row['vendor'] != $current_vendor) {
                if ($current_vendor !== false)
                    echo '[/fancy_table]'; // if we're changing vendors, close the table
            echo '
                

    '.$row['vendor'].'

    [fancy_table] '; $current_vendor = $row['vendor']; } // output the row of data echo ' '; } echo '
    Part Number Quantity Received Quantity Rejected Machine
    '.$row['part_number'].' '.$row['received'].' '.$row['rejected'].' '.$row['machine'].'
    [/fancy_table]'; // close the final table

    On another note, you should start updating this code to use PDO. Obviously, you're in the middle of updating something that used to exist... make PDO a part of this update. The mysql_* functions are on the way to deprecation, and soon they'll be gone.

    PDO is not hard to transition into, and it is MUCH easier now while you're already working on things than it will be later, when you're faced with the "it isn't broke, don't fix it" problem.

    Here's a quick look at your code using the superior PDO DBA method:

       $pdo = new PDO("mysql:host=localhost;dbname=database", '-username-', '-password-');
       $sql = '
            SELECT
                vendor, 
                part_number, 
                machine, 
                SUM(q_received) AS "received",
                SUM(q_rejected) AS "rejected" 
            FROM 
                qa_parts 
            GROUP BY 
                vendor, 
                part_number, 
                machine 
            ORDER BY 
                vendor ASC
        ';
        $statement = $pdo->prepare($sql);
        $statement->execute();
        while ($order = $statement->fetch()) {
            /* Put your table code here! */
        }
    

    Documentation

    • foreach - http://php.net/manual/en/control-structures.foreach.php
    • mysql_query (DEPRECATED) - http://php.net/manual/en/function.mysql-query.php
    • PDO - http://www.php.net/manual/en/book.pdo.php
    • PDO::prepare - http://www.php.net/manual/en/pdo.prepare.php
    • PDOStatement::fetch - http://www.php.net/manual/en/pdostatement.fetch.php
    • PDOStatement::execute - http://www.php.net/manual/en/pdostatement.execute.php

提交回复
热议问题