我创建了一个界面,用户可以在其中选择要显示的结果。用户选择的选项保存在数组中,因此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>";
}
我不确定第二个循环是不是一个好主意,但我不知道我该怎么做才能按我的意愿显示结果。
答案 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>";
}