Mysql
 sql >> база данни >  >> RDS >> Mysql

Всяка стойност се показва в нов ред HTML таблица

Ето целия пример:

<?php
    $con = mysqli_connect('localhost', 'root', '', 'test') or die(mysqli_error($con));
    $query = "SELECT * FROM personeel INNER JOIN rooster ON rooster.personeel_id = personeel.id";
    $result = mysqli_query($con, $query) or die(mysqli_error($con));

    if (mysqli_num_rows($result) > 0) {
        $arr = array();
        $nam = array();
        $day = array('Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday');
        while ($row = mysqli_fetch_assoc($result)) {
            $nam[$row['id']] = $row['naam'];
            $arr[$row['id']][$row['dag']] = $row['start'] . ' - ' . $row['eind'];
        }
        echo '<table border="1">';
            echo '<tr>';
                echo '<td>Employees</td>';
                foreach($day as $d){
                    echo '<td>'.$d.'</td>';
                }
            echo '</tr>';
            foreach ($nam as $k=>$n){
                echo '<tr>';
                    echo '<td>'.$n.'</td>';
                    foreach ($day as $d){
                        if(isset($arr[$k][$d])){
                            echo '<td>'.$arr[$k][$d].'</td>';
                        }else{
                            echo '<td>Virj</td>';
                        }
                    }
                echo '</tr>';
            }
        echo '</table>';
    }
?>

Резултатът е:

Някои подробности:

$nam масивът съхранява всички извлечени имена от personeel заедно с неговата id връзка.

Array
(
    [1] => Tom
    [2] => Jack
)

$arr е основен масив, който съдържа връзката между идентификатора на персонала и неговите данни:

Array
(
    [1] => Array
        (
            [Tuesday] => 12:00 - 21:00
            [Wednesday] => 15:00 - 21:00
        )

    [2] => Array
        (
            [Monday] => 08:00 - 18:30
        )

)

$day е статичен масив с дни от седмицата.

Разходка през двата $nam и $arr arrays ви дава желаната таблица без никакви дубликати. В допълнение предоставеното решение използва mysqli_* функции, за да можете да видите как да ги използвате.

Надяваме се, че това ще ви помогне да разрешите проблема си. :)




  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Използване на php filter_var с mysql_real_escape_string

  2. PDO не може да свърже отдалечен mysql сървър

  3. Вмъкването на нов запис в базата данни по-бързо ли е от проверката дали записът съществува?

  4. „PDOException“ със съобщение „SQLSTATE[HY000] [2002] Няма маршрут до хост

  5. Присъединяване към една и съща таблица няколко пъти в една заявка?