Я сделал некоторые изменения в вашем коде, я добавил пару методов, которые будут получать вам атрибуты и атрибуты со значениями отдельно
Этот метод будет возвращать значения с атрибутами
function getValues($con, $query)
{
....
}
Этот метод даст вам только атрибуты
function getKeys($con, $query)
{
...
}
Он вернет атрибуты, как показано ниже:
Array
(
[0] => ID
[1] => Voornaam
[2] => Achternaam
[3] => Woonplaats
[4] => Postcode
[5] => Email
[6] => Social
[7] => Soort
[8] => Categoriebord
[9] => Categoriegame
)
Вы можете отобразить атрибуты с индексом, например <option value="$row[0]">$row[0]</option>
для атрибута ID
Надеюсь, это поможет вам, просто замените ваш код на этот
function getKeys($con, $query)
{
$result = $con->query($query);
$row = $result->fetch(PDO::FETCH_ASSOC);
return array_keys($row); // This will fetch the keys from an array
}
function getValues($con, $query)
{
$data = $con->query($query);
$data->setFetchMode(PDO::FETCH_ASSOC);
return $data;
}
try {
$con = new PDO('mysql:host=localhost;dbname=snm', "root", "");
$con->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$query = "SELECT ID,Voornaam,Achternaam,Woonplaats,Postcode,Email,Social,Soort,Categoriebord,Categoriegame FROM gebruiker";
//Select Box
$data = getKeys($con, $query);
print '<select>';
foreach ($data as $row) {
print " <option value='".$row[0]."'>".$row[0]."</option>"; // ID
print " <option value='".$row[1]."'>".$row[1]."</option>"; // Voornaam
print " <option value='".$row[2]."'>".$row[2]."</option>"; // Achternaam
}
print '</select>';
//Title
print "<table>";
$array_keys = getKeys($con, $query);
print " <tr>";
foreach ($array_keys as $value) {
print " <th>$value</th>";
}
print " </tr> ";
//Values
$data = getValues($con, $query);
foreach ($data as $row) {
print " <tr> ";
foreach ($row as $name => $value) {
print " <td>$value</td> ";
}
print " </tr> ";
}
print "</table> ";
} catch (\PDOException $e) {
throw new \PDOException($e->getMessage(), (int)$e->getCode());
}