В сфере управления данными могут возникнуть сценарии, когда вам необходимо сгруппировать результаты базы данных по полевым данным и отображать их в определенном формате. Рассмотрим следующие примеры:
Пример 1:
Организация списка имен на основе идентификатора группы:
Пример 2:
Объедините соответствующие заголовки и значения коэффициентов на основе общего идентификатора группы:
Для решения этих проблем возникают два основных подхода: SQL и PHP.
Подход SQL
Для простых задач группировки SQL предоставляет встроенные функции. В первом примере вы можете использовать GROUP_CONCAT() для объединения имен внутри каждой группы, как показано ниже:
SELECT
`Group`,
GROUP_CONCAT(`Name`) AS `names`
FROM YOUR_TABLE
GROUP BY `Group`
Подход PHP
Для более сложных сценариев PHP предлагает большую гибкость. Рассмотрим второй пример, где вам необходимо соединить заголовки и коэффициенты:
// Establish connection
$dbc = new MySQLI(...);
// Execute query
$result = $dbc->query("
SELECT
p.`Group` AS `group`,
a.`title`,
b.`meta_value` AS `coef`
FROM prueba AS p
INNER JOIN table_a AS a
ON p.`meta_value` = a.`id`
LEFT JOIN table_b AS b
ON p.`meta_value` = b.`id`
GROUP BY p.`Group`
");
// Display in HTML table
echo '';
Отказ от ответственности: Все предоставленные ресурсы частично взяты из Интернета. В случае нарушения ваших авторских прав или других прав и интересов, пожалуйста, объясните подробные причины и предоставьте доказательства авторских прав или прав и интересов, а затем отправьте их по электронной почте: [email protected]. Мы сделаем это за вас как можно скорее.
Copyright© 2022 湘ICP备2022001581号-3