«Нет данных в таблице», даже если данные существуют в таблице

Почему в моей таблице отображается ошибка «Нет данных в таблице», а ниже отображается «Показано 0 из 0 записей». Вот скриншот

Понятия не имею, почему это происходит. Я использую mysqli_fetch_assoc для получения данных из моего запроса.

<div class = "card mb-3">
    <div class = "card-header">
        <i class = "fas fa-table"></i>
        Data Table
    </div>
    <div class = "card-body">
        <div class = "table-responsive">
            <table class = "table table-bordered" id = "dataTable" width = "100%" cellspacing = "0">
                <thead>
                    <tr>
                        <th>Ref. No.</th>
                        <th>Date/Time</th>
                        <th>Line No.</th>
                        <th>Optr. Name</th>
                        <th>Weight</th>
                        <th>Moisture</th>
                        <th>Product ID</th>
                        <th>Item Code</th>
                    </tr>
                    <?php while ($rows = mysqli_fetch_assoc($sql)) { ?>
                        <tr>
                            <td><?php echo $rows['mb_refno']; ?></td>
                            <td><?php echo $rows['mb_weight_dt']; ?></td>
                            <td><?php echo $rows['mb_line_id']; ?></td>
                            <td><?php echo $rows['mb_opt_name']; ?></td>
                            <td><?php echo $rows['mb_weight']; ?></td>
                            <td><?php echo $rows['mb_moisture']; ?></td>
                            <td><?php echo $rows['mb_prod_id']; ?></td>
                            <td><?php echo $rows['mb_prod_code']; ?></td>
                        </tr>
                    <?php } ?> 
                </tbody>
            </table>
        </div>
    </div>
    <div class = "card-footer small text-muted">Updated yesterday at 11:59 PM</div>
</div>


<tbody>
  <?php while ($rows = mysqli_fetch_assoc($sql)) { ?>
    <tr>
      <td><?php echo $rows['mb_refno']; ?></td>
      <td><?php echo $rows['mb_weight_dt']; ?></td>
      <td><?php echo $rows['mb_line_id']; ?></td>
      <td><?php echo $rows['mb_opt_name']; ?></td>
      <td><?php echo $rows['mb_weight']; ?></td>
      <td><?php echo $rows['mb_moisture']; ?></td>
      <td><?php echo $rows['mb_prod_id']; ?></td>
      <td><?php echo $rows['mb_prod_code']; ?></td>
    </tr>
    <?php } ?>  
</tbody>

Вам нужно сначала выполнить запрос к базе данных, прежде чем вы сможете прочитать результат. Если вы действительно сначала выполняете запрос, включите его в свой пример кода.

Marijn van Vliet 10.10.2018 08:45

Я думаю, что структура таблицы таблицы данных неверна. Сначала вы отображаете данные из базы данных в <thead> </thead>, а после этого вы используете тот же ресурс и цикл while в <tbody> </tbody>. Я думаю, что после использования ресурса один раз в цикле он опустошается.

Umair Khan 10.10.2018 08:46

используйте num_rows перед использованием цикла while

TarangP 10.10.2018 08:47
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
3
383
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Вы можете прочитать результаты вашего запроса с помощью mysqli_fetch_assoc только один раз. Если вы попытаетесь прочитать его снова, вы получите сообщение об ошибке. Если вы действительно хотите дважды прочитать результат запроса, вы должны сначала выполнить запрос еще раз.

Ответ принят как подходящий

FYI dataTables требует хорошо сформированной таблицы. Он должен содержать теги <thead> и <tbody>, в противном случае возникает эта ошибка. Также убедитесь, что все ваши строки, включая строку заголовка, имеют одинаковое количество столбцов.

<div class = "card mb-3">
    <div class = "card-header">
        <i class = "fas fa-table"></i>
        Data Table
    </div>
    <div class = "card-body">
        <div class = "table-responsive">
            <table class = "table table-bordered" id = "dataTable" width = "100%" cellspacing = "0">
                <thead>
                    <tr>
                        <th>Ref. No.</th>
                        <th>Date/Time</th>
                        <th>Line No.</th>
                        <th>Optr. Name</th>
                        <th>Weight</th>
                        <th>Moisture</th>
                        <th>Product ID</th>
                        <th>Item Code</th>
                    </tr>
                 </thead>
                 <tbody>
                    <?php while ($rows = mysqli_fetch_assoc($sql)) { ?>
                        <tr>
                            <td><?php echo $rows['mb_refno']; ?></td>
                            <td><?php echo $rows['mb_weight_dt']; ?></td>
                            <td><?php echo $rows['mb_line_id']; ?></td>
                            <td><?php echo $rows['mb_opt_name']; ?></td>
                            <td><?php echo $rows['mb_weight']; ?></td>
                            <td><?php echo $rows['mb_moisture']; ?></td>
                            <td><?php echo $rows['mb_prod_id']; ?></td>
                            <td><?php echo $rows['mb_prod_code']; ?></td>
                        </tr>
                    <?php } ?> 
                </tbody>
            </table>
        </div>
    </div>
    <div class = "card-footer small text-muted">Updated yesterday at 11:59 PM</div>
</div>

спасибо, я только забыл </thead>, он исправил мою ошибку и показал результаты 4 из 4, спасибо

DDay 10.10.2018 09:05

Другие вопросы по теме