У меня есть 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, но это было бы слишком долго. Я думаю, что должен быть более легкий путь. Могу ли я получить помощь с этим, пожалуйста? Благодарю.
Вы можете получить желаемый результат, используя этот подход
// 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> '.$rows[$i][$_key].' </td>';
}
$html .= '</tr>';
print_r($rows[$i]);echo '<hr>';
$i++;
}
}
$html .= '</table>';
echo $html;