Wie man mehrere Spalten in einer Variablen in mysql Abfrage erhalten
-
01-10-2019 - |
Frage
Ich habe die Tabelle
Articles -------- id,name,type_id
Type--------------id,name
article_type ----------article_id , type_id
ich mit dieser Abfrage
select A.name from types A
inner join article_type B on ( B.type_id = A.id and article_id = 10)
Nun ist diese Abfrage funktioniert, aber es gibt mir trennen Reihen, aber ich möchte alle Arten in einer Variablen, so dass ich wie in Tabellenformat anzeigen kann
Article name ------------types
milk--------------------dairy , persishable , costly
Lösung
Verwenden von MySQL GROUP_CONCAT Funktion
SELECT a.name AS article_name,
GROUP_CONCAT(t.name) AS types
FROM ARTICLES a
JOIN ARTICLE_TYPE at ON at.article_id = a.id
JOIN TYPE t ON t.id = at.type_id
GROUP BY a.name
Andere Tipps
Wenn ich richtig versteht, ist der Trick CONCAT
zu verwenden, wie in SELECT CONCAT(A.name, ',',B.type) AS synth FROM...
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow