php - 在单个表中显示 MySQL 结果

标签 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>";
}

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

最佳答案

尝试先取出所有列,然后将其添加到 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>";
}

关于php - 在单个表中显示 MySQL 结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31000985/

相关文章:

php - 如何将此 Laravel PHP 代码简化为一个 Eloquent 查询?

php - Symfony Twig : Why use asset method?

php - 如何随机从数据库中检索问题?

c# - 如何最大化性能?

database - Exasol 数据库中最后一次修改的跟踪时间

php - PHP 中的 DOMDocument

mysql - 如何将所有值列表添加到 mysql 数据库并继续添加,即使有重复的主键?

java - 从 MySQL 数据库插入到 mdb

database - 如何在数据库中插入印度卢比符号(Oracle 10g、MySql 5.0 和 Sql Server 2008)?

PHP类型匹配