Разделение строк таблицы на разные столбцы в соответствии с их значением

0

У меня есть mysql таблицы id, gra, grb целые числа и NOT NULLS, и они содержат РАЗНЫЕ числа между 1 и 10. Я хотел бы разделить данные из gra и grb на разные столбцы в соответствии с их значением.

пример: таблица mysql:

+------------+------------+------------+
| id         | gra        | grb        |
+------------+------------+------------+ 
| 1          | 2          | 6          |
+------------+------------+------------+ 
| 2          | 10         | 8          |
+------------+------------+------------+ 
| 3          | 9          | 5          |
+------------+------------+------------+ 

etc

Ожидаемый вывод таблицы будет выглядеть так:

+------------+------------+------------+------------+------------+------------+------------+------------+------------+------------+
| gr1        | gr2        | gr3        | gr4        | gr5        |gr6         | gr7        |gr8         |gr9         |gr10        |
+------------+------------+------------+------------+------------+------------+------------+------------+------------+------------+
|            | 2          |            |            |            | 6          |            |            |            |            |
+------------+------------+------------+------------+------------+------------+------------+------------+------------+------------+
|            |            |            |            |            |            |            | 8          |            | 10         |
+------------+------------+------------+------------+------------+------------+------------+------------+------------+------------+
|            |            |            |            | 5          |            |            |            | 9          |            |
+------------+------------+------------+------------+------------+------------+------------+------------+------------+------------+

Есть простой способ сделать это? Я подумал, что мог бы сделать это, используя mysql с функцией CASE, но это было бы слишком долго. Я думаю, что должен быть более легкий путь. Могу ли я получить помощь с этим, пожалуйста? Благодарю.

  • 0
    Это просто бессмысленная куча цифр. Что здесь происходит? Какой алгоритм вы используете?
  • 0
    Мне нужно разделить данные из gra и grb на разные столбцы (gr1-gr10) в соответствии с их значением от 1 до 10.
Показать ещё 4 комментария
Теги:

1 ответ

1

Вы можете получить желаемый результат, используя этот подход

// Create connection
$conn = new mysqli('hostname', 'username', 'password', 'dbname');
// Check connection
if ($conn->connect_error) {
  die("Connection failed: " . $conn->connect_error);
} 
$sql    = "SELECT gra ,grb FROM 'tablename'";
$result = $conn->query($sql);
$rows   = array();
$i = 0;
if ($result->num_rows > 0) {

 while($row = $result->fetch_assoc()) {
    foreach(range(1,10) as $key => $value){
        $_key = 'gr'.$value;
        $rows[$i][$_key] = ($row['gra'] == $value) ? $row['gra'] : ( ($row['grb'] == $value) ? $row['grb'] : null);
    }
    $i++;
  }
}
echo '<pre>';
print_r($rows);

Вы можете напечатать в таблице, как это

$sql    = "SELECT gra ,grb FROM 'grade'";
$result = $conn->query($sql);
$rows   = array();
$i = 0;
$html = '<table border="1"><tr>';
foreach(range(1,10) as $v){
  $html.= '<td>gr'.$v.'</td>';
}
$html .= '</tr>';
if ($result->num_rows > 0) {
while($row = $result->fetch_assoc()) {
  $html .= '<tr>';
  foreach(range(1,10) as $key => $value){
    $_key = 'gr'.$value;
     $rows[$i][$_key] = ($row['gra'] == $value) ? $row['gra'] : ( ($row['grb'] == $value) ? $row['grb'] : null);
     $html .= '<td>&nbsp;'.$rows[$i][$_key].'&nbsp;</td>';
   }
   $html .= '</tr>';
   print_r($rows[$i]);echo '<hr>';
   $i++;
 }
}
$html .= '</table>';
echo $html;

Ещё вопросы

Сообщество Overcoder
Наверх
Меню