MYSQL форматирование даты с использованием группы concat
Извините за репост, но на этот вопрос я получил большую часть ответа месяц назад. Но до сих пор не работает полностью так, как я хочу.
Имейте поле даты, которое я получаю из моей БД со следующим;
SELECT event,event_name,
GROUP_CONCAT(DATE_FORMAT(ed.date,'%b %e') ORDER BY ed.date SEPARATOR ',') as date2
FROM events ev
LEFT JOIN event_dates ed ON ev.eid=ed.eid
WHERE ev.yr='2013'
GROUP BY ev.eid
Это создает этот список дат, который занимает много места.
16 мая, 23 мая, 30 мая, 6 июня, 20 июня
Я хочу, чтобы это выглядело как
16,23,30 мая, 6,20 июня
Вот запрос, который я попытался на основе ввода в прошлый раз. но это не работает, потому что подзапрос, кажется, не знает идентификатор события. Угадай, мне может понадобиться преобразовать его в соединение?
SELECT DISTINCT ev.event_id,
GROUP_CONCAT(DISTINCT DATE_FORMAT(race_date,'%a') ORDER BY race_date
SEPARATOR ', ') as date1,
(SELECT GROUP_CONCAT(dm) FROM
(SELECT CONCAT(
MONTHNAME(race_date),
' ',
GROUP_CONCAT(DAY(race_date) ORDER BY race_date)
) as dm
FROM event_dates ed1 WHERE ed1.event_id=ev.event_id
GROUP BY MONTH(race_date))as t) as date2
FROM events ev
JOIN event_dates ed ON ev.event_id = ed.event_id AND ev.race_year = ed.race_year
GROUP BY event_id
1 ответ
Это должно приблизить вас к тому, что вы ищете:
SELECT event_name, date2
FROM (
SELECT
@showMonth:=IF(CONCAT(MONTHNAME(ed.date),ev.eid)=@prevMonth,'',CONCAT(MONTHNAME(ed.date), ' ')),
event_name,
MONTHNAME(ed.date),
GROUP_CONCAT(CONCAT(@showMonth, DATE_FORMAT(ed.date,'%e')) ORDER BY ed.date SEPARATOR ',') as date2,
@prevMonth:=CONCAT(MONTHNAME(ed.date),ev.eid)
FROM events ev
LEFT JOIN event_dates ed ON ev.eid=ed.eid
JOIN (SELECT @showMonth:='', @prevMonth:='') r
WHERE ev.yr=2013
GROUP BY ev.eid
) t