0

所以,我有一个复选框,允许用户选择他们想要查看的列。因此,例如,如果用户只想选择 2 列(例如,TicketID 和 Category),它将只显示 ID 的数据和票的类别。这是我到目前为止所拥有的:

形式:

    <form action="<?php echo $_SERVER['PHP_SELF']; ?>" method="post">
    <ul>
        <li><input type="checkbox" name="filter[]" value="TicketID" >Ticket ID</li>
        <li><input type="checkbox" name="filter[]" value="Category" />Category</li>
        <li><input type="checkbox" name="filter[]" value="Priority" />Priority</li>
        <li><input type="checkbox" name="filter[]" value="Status" />Status</li>
        <li><input type="checkbox" name="filter[]" value="InitialDescription" />Initial Description</li>
        <li><input type="checkbox" name="filter[]" value="SubmittedDate" />Submitted Date</li>
        <li><input type="checkbox" name="filter[]" value="Description" />Status Description</li>
        <input type="submit" value="Refresh Filters">
    </ul>
</form>
</td>
<td>
    <?php 


    viewTicketTable($_SESSION['userID'],$_POST['filter']);

        ?>

viewticketTable 函数:

function viewTicketTable($userID,$columns) {
/* Accepts $userID which will identify the tickets related with the user and
$columns which will filter only the columns that are required and outputs the
table with the columns passed through. */


/* 
$columns_array = explode(',', $columns);

foreach($array as $array){
    echo $array;
} */


foreach($columns as $filter) {
    $filter = $filter  . ',' ;

}

$filter = substr($filter, 0, -1);   


$query = mysql_query("
SELECT $filter
FROM Ticket
LEFT JOIN TicketHistory
ON Ticket.TicketID = TicketHistory.TicketID
WHERE CustomerID = $userID;
");



/* Creation of the table */
echo '
    <table border="1">
        <thead>
            <tr>';
            foreach($columns as $tableHeader) {
                $tableHeader = '<th scope="col">' . $tableHeader  . '</th>' ;
                echo $tableHeader;
            }
echo '
            </tr>
        </thead>
        <tbody>
';

/*Looping through the script to print out all the information.*/
while ($row = mysql_fetch_array($query) or die(mysql_error())) {
    echo '
            <tr>';
                foreach($columns as $field) {
                    echo '<td>' . $row[$field] . '</td>';
                }
            echo '</tr>
    ';
}


echo '  </tbody>
    </table>';

}

问题出在 while 循环中。row[$field] 仅填充最后一列,而不是全部填充。有什么帮助吗?

4

2 回答 2

0

我修好了它。如果有人有同样的问题,我会发布答案。

问题在这里得到解决:

    $filter = "";
foreach($columns as $c) {
    $filter = $filter . $c  . ',' ;

}

$filter = substr($filter, 0, -1);   

循环没有将值分配给 $filter 变量,因此我必须创建一个外部变量。foreach 循环中还有另一个错误,我必须用 if 语句修复(不是最好的方法,但它有效):

foreach($columns as $field) {
if ($field == 'Ticket.TicketID'){
    $field = 'TicketID';
}
echo '<td>' . $row[$field] . '</td>';
}

$row 数组中不接受 Ticket.TicketID,因此我不得不将其更改为 TicketID

无论如何感谢大家的帮助。

于 2013-04-14T13:23:22.980 回答
0

您的 SQL 语法有错误 -在结束;前您有一个额外的错误"

此外,您应该使用mysql_fetch_assoc代替mysql_fetch_arrayas usingmysql_fetch_array而不指定方法将返回一个双数组。

于 2013-04-12T13:07:46.983 回答