在单个表中显示MySQL结果

时间:2015-06-23 11:00:56

标签: php mysql database

我创建了一个界面,用户可以在其中选择要显示的结果。用户选择的选项保存在数组中,因此MySQL查询将遍历此数组的不同元素。

所以我想在一个表中显示结果......就像这样:

标题1 | 标题2

结果1-1 |结果1-2

结果2-1 |结果2-2

我的代码如下:

$mark = $_POST['mark'];
if (isset($_POST['mark']) && is_array($_POST['mark'])) {
    echo "<table border='1'>";
    echo "<tr>";
    for ($i = 0; $i < count($mark); $i++) {
            echo "<th>" . $mark[$i] . "</th>";
    }
    echo "</tr>";

    for ($i = 0; $i < count($mark); $i++) {
        $markQuery = "SELECT $mark[$i] FROM marks LIMIT 10";
        $result = mysqli_query($DB_connection, $markQuery);
        echo "<tr>";
        while($row= mysqli_fetch_assoc($result)){
            echo "<td>" .  $row[$mark[$i]] . "</td>";
            }
        echo "</tr>";
        }
        echo "</table>";
}

我不确定第二个循环是不是一个好主意,但我不知道我该怎么做才能按我的意愿显示结果。

1 个答案:

答案 0 :(得分:0)

首先尝试获取所有列,然后将其添加到sql查询中,无需循环数据库查询。

$mark = $_POST['mark'];
if (isset($_POST['mark']) && is_array($_POST['mark'])) {
    echo "<table border='1'>";
    echo "<tr>";
    for ($i = 0; $i < count($mark); $i++) {
            echo "<th>" . $mark[$i] . "</th>";
    }
    echo "</tr>";

    $sql = implode(',', $_POST['marks']);

    $markQuery = "SELECT ".$sql." FROM marks LIMIT 10";
    $result = mysqli_query($DB_connection, $markQuery);
    echo "<tr>";
    while($row= mysqli_fetch_assoc($result)){
        echo "<td>" .  $row[$mark[$i]] . "</td>";
    }
    echo "</tr>";
    echo "</table>";
}