Извлечение таблицы из SQL дБ

php html mysqli html-table

41 просмотра

1 ответ

26 Репутация автора

Я настроил Wamp-сервер. Я загрузил таблицу с именем stud в phpMyAdmin в тесте базы данных. Теперь я хочу отобразить его в веб-браузере в виде таблицы со строками в качестве разделителей. Я написал следующий код как PHP. Когда я пытался запустить localhost / hw.php, ошибка была следующей:

<html>
    <head>
        <title>mysqli Table Viewer</title>
    </head>
    <body>
        <?php
        $db_host = 'localhost';

        $database = 'test';
        $table = 'stud';

        if (!mysqli_select_db($database))
            die("Can't select database");

        // sending query
        $result = mysqli_query("SELECT * FROM {$table}");
        if (!$result) {
            die("Query to show fields from table failed");
        }

        $fields_num = mysqli_num_fields($result);

        echo "<h1>Table: {$table}</h1>";
        echo "<table border='1'><tr>";

        // printing table headers
        for($i=0; $i<$fields_num; $i++)
        {
            $field = mysqli_fetch_field($result);
            echo "<td>{$field->name}</td>";
        }
        echo "</tr>\n";

        // printing table rows
        while($row = mysqli_fetch_row($result))
        {
            echo "<tr>";

            // $row is array... foreach( .. ) puts every element
            // of $row to $cell variable
            foreach($row as $cell)
                echo "<td>$cell</td>";

            echo "</tr>\n";
        }

        mysqli_free_result($result);
        ?>
    </body>
</html>

Как я могу исправить эту ошибку?

Автор: Melko Источник Размещён: 18.07.2016 05:18

Ответы (1)


0 плюса

8639 Репутация автора

Решение

Прежде чем получить доступ к таблице, вы должны подключиться к базе данных, это подключение необходимо для всех операций над базой данных. В следующем коде я использую стрелки ( // ◄■■■), чтобы указать на изменения (обратите внимание на $cnxпеременную):

<html>
<head>
<title>mysqli Table Viewer
</title></head><body>
<?php
$db_host = 'localhost';

$database = 'test';
$table = 'stud';

$cnx = mysqli_connect( $db_host, "root", "", $database ) //◄■■■■■■■■■■■■■■
       or die(mysqli_error($cnx));

if (!mysqli_select_db( $cnx, $database ) )               //◄■■■■■■■■■■■■■■
    die("Can't select database");

// sending query
$result = mysqli_query( $cnx, "SELECT * FROM {$table}" );  //◄■■■■■■■■■■■
if (!$result) {
    die("Query to show fields from table failed");
}

$fields_num = mysqli_num_fields($result);

echo "<h1>Table: {$table}</h1>";
echo "<table border='1'><tr>";
// printing table headers
for($i=0; $i<$fields_num; $i++)
{
    $field = mysqli_fetch_field($result);
    echo "<td>{$field->name}</td>";
}
echo "</tr>\n";
// printing table rows
while($row = mysqli_fetch_row($result))
{
    echo "<tr>";

    // $row is array... foreach( .. ) puts every element
    // of $row to $cell variable
    foreach($row as $cell)
        echo "<td>$cell</td>";

    echo "</tr>\n";
}
mysqli_free_result($result);
?>
</body>
</html>
Автор: Jose Manuel Abarca Rodríguez Размещён: 18.07.2016 05:29
Вопросы из категории :
32x32