Как отобразить значения в HTML, которые приходят из mysqli_multi_query в переполнение стека

Я могу получить значения, отображаемые из базы данных при использовании mysqli_multi_query.Но я не могу печатать в своем HTML-коде. Вероятно, это проблема цикла while. Ниже мой код, который дает мне AVG для трех операторов SQL. Единственная проблема заключается в отображении среднего значения в HTML.

<?php
$con = new mysqli("localhost", "root","","survey");
if ($con){ printf(""); }

$query  = "SELECT AVG(workarea) FROM score;" ;
$query .= "SELECT AVG(manager) FROM score;";
$query .= "SELECT AVG(comm) FROM score;";

// Execute multi query
if (mysqli_multi_query($con,$query)) {
do {
if ($result=mysqli_store_result($con)) {
// Fetch one and one row
while ($row=mysqli_fetch_row($result)) {
printf("%s\n",$row[0]);
}

// Free result set
mysqli_free_result($result);
}
} while (mysqli_next_result($con));
}
?>
<div class="row count">
WORK AREA/UNIT SCORE : <?php echo $row[0]; ?> // echo $row[AVG(workarea)]  doesnot work
</div>

<div class="row count">
SUPERVISOR/MANAGER SCORE : <?php echo $row[0]; ?> // echo $row[AVG(manager)]
</div>

<div class="row count">
COMMUNICATION SCORE : <?php echo $row[0]; ?> // echo $row[AVG(comm)] doesnot work
</div>

0

Решение

Нет необходимости в нескольких запросах, вы просто получаете AVG в одном запросе. И напишите свой HTML внутри цикла, как

 $con = new mysqli("localhost", "root", "", "survey");
if ($con) {
printf("");
}
$query = "SELECT AVG(workarea),AVG(manager),AVG(comm) FROM score;";
// Execute multi query
if ($result = $con->query($query)) {

/* fetch object array */
while ($row = $result->fetch_row()) {
?>
<div class="row count">
WORK AREA/UNIT SCORE : <?php echo $row[0]; ?>
</div>

<div class="row count">
SUPERVISOR/MANAGER SCORE : <?php echo $row[1]; ?>
</div>

<div class="row count">
COMMUNICATION SCORE : <?php echo $row[2]; ?>
</div>
<?php
}

/* free result set */
$result->close();
}
2

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]