Я использую SQLite и имею три таблицы (в этих таблицах больше данных - сокращенно здесь):
- Категории – содержит категории элементов (идентификатор, название, описание).
- Элементы – (идентификатор, название, статус)
- Ссылка (id, cat_id, item_id)
Категории могут иметь много элементов, связанных с ним, или ни одного. Элементы должны иметь как минимум 1 категорию и могут быть более чем в 1 категории.
Пример:
(Categories)
| id | name | description |
|----|--------|---------------------------------|
| 1. | wet. | something associated with water |
| 2. | dry. | something else |
| 3. | metal. | steel, copper |
(Items)
| id. | name. | status |
|-----|---------|------------|
| 11. | river. | north fork |
| 12. | lake. | big |
| 13. | river. | south fork |
| 14. | desert. | mojave |
| 15. | car. | ford |
| 16. | truck. | chevy |
(Reference)
| id | cat_id. | item_id |
|----|---------|---------|
| 21 | 1 | 11 |
| 22 | 1 | 12 |
| 23 | 2 | 14 |
| 24 | 3 | 15 |
| 25 | 3 | 16 |
Используя следующее:
SELECT c.name,(i.name || "-" || i.status) as Related from Items as i
join Categories c where c.id = cat.id
Я получаю что-то вроде этого:
| c.name | Related |
|---------|--------------------|
| wet | river - north fork |
| wet | lake - big |
| wet | river - south fork |
| dry | desert - mojave |
| metal | car - ford |
| metal | truck - chevy |
Мне нужно
| c.name | Related |
|--------|----------------------------------------------------|
| wet | river - north fork, lake - big, river - south fork |
| dry | desert - mojave |
| metal | car - ford, truck - chevy |
Одна категория соответствует элементам, на которые есть ссылки в соединительной таблице, и объединяется в столбце «Связанные» (разделенные запятой в примере).
Как мне получить этот результат в SQLite?