Diskuze: Výpis udajov z databáze do HTML tabuľky
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Tvůrce

Zobrazeno 17 zpráv z 17.
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Hodíš SELECT na všechny řádky a potom v cyklu všechny řádky vypíšeš.
Ako to myslíš ? Stále sa zdelávam a som toho názoru že nevedieť
neznamená byť blbý, blbý si vtedy ak sa na to neopýtaš
Vyber si data do proměnné např. $uzivatele. To potom dej do foreach nějak takto:
<?php
// Kód, pro výběr z databáze na proměnnou $uzivatele.
?>
<table>
<tr>
<th>id</th>
<th>nick</th>
</tr>
<?php foreach($uzivatele as $u) : ?>
<tr>
<td><?= $u['id'] ?></td>
<td><?= $u['nick'] ?></td>
</tr>
<?php endforeach ?>
</table>
<?php $membersinfo = mysqli_query($connect, "SELECT * FROM members");
foreach($membersinfo as $u) : ?>
<tr>
<td><?= $u['id'] ?></td>
<td>
<div class="media">
<img src="app/img/user/01.jpg" alt="Image" class="img-responsive img-circle">
</div>
</td>
<td>@twitter</td>
<td>Larry</td>
<td>the Bird</td>
<td>mail@example.com</td>
<td>member</td>
<td>
<div class="checkbox c-checkbox">
<label>
<input type="checkbox">
<span class="fa fa-check"></span>
</label>
</div>
</td>
</tr>
<?php endforeach ?>
Takto ?
Pokud se jedná o výpis všech uživatelů, ano, pokud o jednoho, není
třeba foreach. Akorát nechápu smysl toho tvého cyklu, kde pouze
měníš ID. Ale i tak by to mělo fungovat.
Bolo to pre príklad Ale
bohužial to nefunguje ... Chcem vypísať všetky ID a nevypíše ani jedno
Nějaká chyba?
Pokud ne, zkontroluj správné názvy sloupců.
Pozn.: Pokud potřebuješ jen pár sloupců, můžeš pozměnit dotaz:
SELECT * FROM members
na
SELECT id FROM members
$membersInfoQuery = mysqli_query(...);
$membersInfo = mysqli_fetch_assoc($membersInfoQuery);
foreach ($membersInfo as $member)
Nějak takto by to mělo být. Musíš ta vyhledaná data uložit do pole a teprve potom procházet.
To ti přece nemůže fungovat. Mysqli_query nevrací pole, ale objekt s informacemi o výsledku dotazu.
Dominik Gavrecký
Musíš použít cyklus while a funkci mysqli_fetch_array() (například).
Takto:
$dotaz = mysqli_query($spojeni, "SELECT * ...");
while ($data = mysqli_fetch_array($dotaz)) {
echo $data["nazev_sloupce"];
}
Takto se ti do $memersInfo uloží jen jeden řádek, jich pokud bude očekávat víc, musí to dát do toho cyklu while.
Tak psal, že umí mysqli_fetch_assoc() a tak, takže jsem netušil, že
dělá chybu. Jsem zvyklý na PDO.
Ďakujem veľmi pekne za pomoc
Jasný, jak jsem zvyklej z PDO na fetchAll(), tak jsem si to neuvědomil.
Chalani ospravedlňujem sa ale naskytol sa další problém Všetko funguje ako má ale pri
použití PHP do vypísania udajov do tabuľky mi ju uplne rozhádže. Ale
údaje vypíše správne.
<?php
$membersinfoquery = mysqli_query($connect, "SELECT * FROM members");
while ($data = mysqli_fetch_array($membersinfoquery)) {
?>
<tr>
<td><?= $data['id'] ?></td>
<td>
<div class="media">
<img src="app/img/user/01.jpg" alt="Image" class="img-responsive img-circle">
</div>
</td>
<td><?= $data['id'] ?></td>
<td><?= $data['id'] ?></td>
<td><?= $data['id'] ?></td>
<td><?= $data['id'] ?></td>
<td><?= $data['id'] ?></td>
<td>
<div class="checkbox c-checkbox">
<label>
<input type="checkbox">
<span class="fa fa-check"></span>
</label>
</div>
</td>
</tr>
</tbody>
</table>
<?php } ?>
Vše co je uvnitř cyklu (mezi { a }) se opakuje pro každý řádek z databáze, takže
</tbody>
</table>
musíš dát mimo cyklus.
Zobrazeno 17 zpráv z 17.