Как я могу показать только названия этих данных, которые я взял из своей базы данных? - PullRequest
0 голосов
/ 06 июня 2019

Я создал эту таблицу с информацией, которую имею в своей базе данных, но теперь мне нужно сделать поле выбора со значениями, чтобы я мог показывать только имена, например.Должен ли я использовать операторы if для этого?

<?php
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";
    print "<table>";
    $result = $con->query($query);
    $row = $result->fetch(PDO::FETCH_ASSOC);
    print " <tr>";
    foreach ($row as $field => $value) {
        print " <th>$field</th>";
    }
    print " </tr> ";
    $data = $con->query($query);
    $data->setFetchMode(PDO::FETCH_ASSOC);
    foreach ($data as $row) {
        print " <tr> ";
        foreach ($row as $name => $value) {
            print " <td>$value</td> ";
        }
        print " </tr> ";
    }
    print "</table> ";

} catch (PDOException $e) {
    echo 'ERROR: ' . $e->getMessage();
}
?>

1 Ответ

0 голосов
/ 06 июня 2019

Я сделал некоторые изменения в вашем коде, я добавил пару методов, которые будут получать вам атрибуты и атрибуты со значениями отдельно

Этот метод будет возвращать значения с атрибутами

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());
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...