Mark Rene Jensen Ответов: 1

Я не могу получить всю информацию из своей базы данных?


Если я запускаю это в список на Fusion 2.5, то первая строка показывает мне число "2", так как в базе данных их два! Но он показывает только одну строку из базы данных, так как строка 1 берется из того, сколько их всего?

Не могли бы вы помочь мне пропустить те строки, которые подсчитывают базу данных?


<?php 

if (mysqli_connect_errno())
{
	echo "Connexion impossible ! " . mysqli_connect_error();
}
else
{

  $query = "SELECT * FROM sequencer AS id ORDER BY id DESC";
  
  if ($res0 = $con->query($query))
  {
    $check=$res0->fetch_array(MYSQLI_BOTH);
    $num_row  = mysqli_num_rows($res0);
    echo $num_row;
    echo" | ";
    while (NULL !== ($check = $res0->fetch_array(MYSQLI_BOTH)) ) 
    {
      echo "  | ";
      echo " Pattern1 : ";
      echo " ".$check['pattern1']."  -";
      echo " Pattern2 : ";
      echo " ".$check['pattern2']." ";
      echo "  | ";
    }

  }
}

?>


Что я уже пробовал:

$num_row  = mysqli_num_rows($res0);
должно быть, это проблема, как я вижу...

1 Ответов

Рейтинг:
2

OriginalGriff

Компиляция не означает, что ваш код верен! :смеяться:
Подумайте о процессе разработки как о написании электронного письма: успешная компиляция означает, что вы написали электронное письмо на правильном языке - например, на английском, а не на немецком, - а не то, что письмо содержало сообщение, которое вы хотели отправить.

Итак, теперь вы входите во вторую стадию разработки (на самом деле это четвертая или пятая, но вы перейдете к более ранним стадиям позже): тестирование и отладка.

Начните с рассмотрения того, что он делает, и как это отличается от того, что вы хотели. Это важно, потому что это дает вам информацию о том, почему он это делает. Например, если программа предназначена для того, чтобы позволить пользователю ввести число, а он удваивает его и печатает ответ, то если ввод / вывод был таким:

Input   Expected output    Actual output
  1            2                 1
  2            4                 4
  3            6                 9
  4            8                16
Тогда совершенно очевидно, что проблема заключается в бите, который удваивает его - он не прибавляет себя к себе или умножает его на 2, он умножает его на себя и возвращает квадрат входного сигнала.
Таким образом, вы можете посмотреть на код, и очевидно, что он находится где-то здесь:
int Double(int value)
   {
   return value * value;
   }

Как только у вас появится идея, что может пойти не так, начните использовать отладчик, чтобы выяснить, почему. Поместите точку останова в первую строку метода и запустите приложение. Когда он достигнет точки останова, отладчик остановится и передаст управление вам. Теперь вы можете запускать свой код построчно (так называемый "одноступенчатый") и просматривать (или даже изменять) содержимое переменных по мере необходимости (черт возьми, вы даже можете изменить код и повторить попытку, если вам это нужно).
Подумайте о том, что должна делать каждая строка кода перед ее выполнением, и сравните это с тем, что она действительно делала, когда вы использовали кнопку "Step over" для выполнения каждой строки по очереди. Он сделал то, что вы ожидали? Если да, то переходите к следующей строке.
Если нет, то почему? Чем это отличается?
Надеюсь, это поможет вам определить, в какой части этого кода есть проблема и в чем она заключается.
Это навык, и его стоит развивать, поскольку он помогает вам как в реальном мире, так и в развитии. И, как и все навыки, он только улучшается при использовании!