Не могу получить данные - PullRequest
0 голосов
/ 07 июня 2019

Я пытаюсь получить файл из своей базы данных, который отформатирован как csv (файл Excel), но он даже не передает данные в браузер.

Я не пробовал что-тотем не менее, потому что я боюсь, что сделаю это хуже, чем это ...

Мой PHP-код (я уже подключился к базе данных, но не хочу показывать свою информацию публично):

<?php
error_reporting(E_ALL);
ini_set('display_errors', 1);
mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);

// Create connection
$db = new mysqli($dbhost, $dbusername, $dbpassword, $dbname);

$allData = "";
$query = 'SELECT * FROM members';
  $retval = mysqli_query( $db,$query );
   if(! $retval ) {
      die('Could not get data.');
   }
   while($row = mysqli_fetch_array($retval)) {
  $allData .= $row['Id'] . ',' . $row['Email'] . ',' . $row['Condition'] .     ',' . $row['isEmailConfirmed'] . ',' . $row['Name'] . ',' .         $row['LastName'] . ',' . $row['Token'] . ',' .$row['Type'] . ',' .         $row['extra_privileges'] . ',' . $row['access-to-ftp'] . ',' .$row['access-    to-panel'] . ',' . $row['Birthdate'] . ',' . $row['Password'] . ',' .     $row['Description'] . "\n";
  //$retval = "data:text/csv;charset=utf-    8,ID,EMAIL,CONDITION,ISEMAILCONFIRMED,NAME,LASTNAME,TOKEN,TYPE,EXTRA_PRIVIL    EGES,ACCESS-TO-FTP,ACCESS-TO-PANEL,BIRTHDATE,PASSWORD,DESCRIPTION\n";
  $retval .= $allData;

  echo $retval;
  }
?>

Это просто говорит мне, что я не могу получить данные, которые я имею в качестве решения.

1 Ответ

1 голос
/ 07 июня 2019

Ваша проблема в том, что вы повторно используете одну и ту же переменную и теряете результаты своей БД.

$sql = 'SELECT * FROM members';
$retval = mysqli_query($db, $sql);
// ^^^^ This PHP variable holds your DB results
if (!$retval) {
    die('Could not get data.');
}
//  Each iteration of the loop you reach for a single row from the result $retval
while ($row = mysqli_fetch_array($retval)) {
    $allData .= $row['Id'] . ',' . $row['Email'] . ',' . $row['Condition']     . ',' . $row['isEmailConfirmed'] . ',' . $row['Name'] . ',' .     $row['LastName'] . ',' . $row['Token'] . ',' .$row['Type'] . ',' .     $row['extra_pivileges'] . ',' . $row['access-to-ftp'] . ',' .$row['access-to    panel'] . ',' . $row['Birthdate'] . ',' . $row['Password'] . ',' .     $row['Description'] . "\n";
    $retval = "data:text/csv;charset=utf-8,ID,EMAIL,CONDITION,ISEMAILCONFIRMED,NAME,LASTNAME,TOKEN,TYPE,EXTRA_PRIVILEG    ES,ACCESS-TO-FTP,ACCESS-TO-PANEL,BIRTHDATE,PASSWORD,DESCRIPTION\n";
    $retval .= $allData;
    // ^^^ but here you are using the same variable, thus losing its previous contents. 

    echo $retval;
}

Измените имя вашего результата PHP и не перезаписывайте его. Например:

$sql = 'SELECT * FROM members';
$result_of_DB_select = mysqli_query($db, $sql);
// ^^^^ This PHP variable holds your DB results
if (!$result_of_DB_select) {
    die('Could not get data.');
}

// CSV header before the loop:
$CSV_response = "data:text/csv;charset=utf-8,ID,EMAIL,CONDITION,ISEMAILCONFIRMED,NAME,LASTNAME,TOKEN,TYPE,EXTRA_PRIVILEG    ES,ACCESS-TO-FTP,ACCESS-TO-PANEL,BIRTHDATE,PASSWORD,DESCRIPTION\n";

//  Each iteration of the loop you reach for a single row from the result variable called $result_of_DB_select 
while ($row = mysqli_fetch_array($result_of_DB_select)) {
    $CSV_response .= $row['Id'] . ',' . $row['Email'] . ',' . $row['Condition']     . ',' . $row['isEmailConfirmed'] . ',' . $row['Name'] . ',' .     $row['LastName'] . ',' . $row['Token'] . ',' .$row['Type'] . ',' .     $row['extra_pivileges'] . ',' . $row['access-to-ftp'] . ',' .$row['access-to    panel'] . ',' . $row['Birthdate'] . ',' . $row['Password'] . ',' .     $row['Description'] . "\n";
    // ^^^ different variable holds your CSV response now and you will not lose contents of $result_of_DB_select. 
}
echo $CSV_response;
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...