Отображение цикла над запросом PHP/MySQL в массиве

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

Это мой сценарий:

/*
 * View
 */

$query = "SELECT u.lastname as nom, u.firstname as prenom, u.datelastlogin as lastlogin";
$query.= " FROM ".MAIN_DB_PREFIX."user as u";
$query.= " ORDER BY lastlogin DESC LIMIT 2";

$resql = $db ->query($query);
$num = $db->fetch_row($resql);

print '<table class="noborder" width="100%">';
print '<tr class="liste_titre"><th colspan="2">'.$langs->trans("Affichage des 2 dernières connexions").'</th></tr>';
if (! empty($conf->user->enabled))
{
        $LastLogin = '<tr class="oddeven">';
        $LastLogin.= '<td><a href="index.php">'.$langs->trans("Utilisateur").'</a></td><td align="right">'.$num[0]." ".$num[1]." ".$num[2].'</td>';
        $LastLogin.= "</tr>";
}

print $LastLogin;
print '</table>';

До сих пор я возвращаю только первую строку из моего запроса. Я никогда не программировал на PHP раньше, и я хотел бы знать, как я могу отобразить каждую строку из моего запроса в моем массиве?

Я должен измениться fetch_row в fetch_array?

Или, может быть, лучше разделить мой массив на 3 столбца (имя столбца, имя столбца, столбец datelastlogin)

Что-то вроде этого:

Я не очень понимаю, как я могу это сделать.

Спасибо за помощь

РЕДАКТИРОВАТЬ:

Я отредактировал мой сценарий:

$query = "SELECT u.lastname as nom, u.firstname as prenom, u.datelastlogin as lastlogin";
$query.= " FROM ".MAIN_DB_PREFIX."user as u";
$query.= " ORDER BY lastlogin DESC LIMIT 2";

$resql = $db ->query($query);
//$num = $db->fetch_array($resql);
while($num = $resql->fetch_assoc())
{
    $nums[] = $num;
}

print '<table class="noborder" width="100%">';
print '<tr class="liste_titre"><th colspan="2">'.$langs->trans("Dernières connexions").'</th></tr>';
if (! empty($conf->user->enabled))
{
    foreach($nums as $num)
    {
        $LastLogin = '<tr class="oddeven">';
        $LastLogin.= '<td><a href="index.php">'.$num['nom'].'</a></td><td>'.$num['prenom'].'</td><td>'.$num['lastlogin'].'</td>';
        $LastLogin.= "</tr>";
    }
}
print $LastLogin;
print '</table>';

Но массив плохо отображается:

1 ответ

Решение

Привет снова:)

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

Давайте посмотрим на ваш код:

if (! empty($conf->user->enabled))
{
    foreach($nums as $num)
    {
        $LastLogin = '<tr class="oddeven">';
        $LastLogin.= '<td><a href="index.php">'.$num['nom'].'</a></td><td>'.$num['prenom'].'</td><td>'.$num['lastlogin'].'</td>';
        $LastLogin.= "</tr>";
    }
}
print $LastLogin;

Проблема в том, что вы перезаписываете $LastLogin все время. Это будет работать так же, как в фитоне. Таким образом, у вас есть два варианта:

  1. Поместите отпечаток в петлю.
  2. Выведите результат прямо внутри цикла.

Я не буду делать пример для 1 так как его единственное размещение print $LastLogin внутри цикла foreach - вам не нужен пример для этого.

Ниже я покажу вам код, как я написал бы это в вашем случае:

$query = "SELECT u.lastname as nom, u.firstname as prenom, u.datelastlogin as lastlogin";
$query.= " FROM ".MAIN_DB_PREFIX."user as u";
$query.= " ORDER BY lastlogin DESC LIMIT 2";

$resql = $db ->query($query);
//$num = $db->fetch_array($resql);

print '<table class="noborder" width="100%">';
print '<tr class="liste_titre"><th colspan="2">'.$langs->trans("Dernières connexions").'</th></tr>';

if (! empty($conf->user->enabled)) {

    while($num = $resql->fetch_assoc()) {
        print '<tr class="oddeven">';
        print '<td><a href="index.php">'.$num['nom'].'</a></td><td>'.$num['prenom'].'</td><td>'.$num['lastlogin'].'</td>';
        print '</tr>';
    }
}

print '</table>';

На самом деле нет необходимости сохранять все свои результаты в var и добавлять к нему все время. Просто распечатайте результаты напрямую, и ничто не сможет вас удержать. Конечно, мы могли бы сейчас сказать о разделении логики и представлений - но в этом случае в этом нет особой необходимости.

Надеюсь, это помогло:)

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