У меня есть база данных следующим образом:
---------------------------------------------------------------
| module_name | category | content |
---------------------------------------------------------------
| module1 | category1 | content |
| module2 | category1 | content |
| module3 | category2 | content |
| module4 | category3 | content |
| module5 | category2 | content |
---------------------------------------------------------------
Я хочу иметь возможность создавать группы результатов, но не могу найти самый быстрый и эффективный способ сделать это без вложенных запросов MySQL. Результат должен выглядеть следующим образом (стиль игнорируется):
---------------------------------------------------------------
| module1 | category1 | content |
| module2 | category1 | content |
---------------------------------------------------------------
---------------------------------------------------------------
| module3 | category2 | content |
| module5 | category2 | content |
---------------------------------------------------------------
---------------------------------------------------------------
| module4 | category3 | content |
---------------------------------------------------------------
Мой код выглядит так:
$query = 'SELECT'
. ' DISTINCT'
. ' category AS name'
. ' FROM #__table'
. ' WHERE enabled = 1';
$db->setQuery($query);
$categories = $db->loadObjectList();
foreach ($categories as $category) {
$query = 'SELECT'
. ' module_name'
. ' FROM #__table'
. ' WHERE enabled = 1 AND category = \'' . $category->name . '\''
. ' ORDER BY id';
$db->setQuery($query);
$results = $db->loadObjectList();
foreach ($results as $result) {
echo $result->module_name;
}
}
Это вложенный запрос, который работает, но есть ли лучший способ сделать это?