0

再投稿して申し訳ありませんが、これは 1 か月前にほとんどの回答を得た質問です。しかし、まだ完全に思いどおりに機能していません。

次のようにDBから取得する日付フィールドがあります。

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

これにより、多くのスペースを占める日付のリストが生成されます。

5月16日、5月23日、5月30日、6月6日、6月20日

のようにしたい

5月16日、23日、30日、6月20日

前回の入力に基づいて試したクエリは次のとおりです。サブクエリがイベントIDを認識していないように見えるため、機能しません。私はそれを結合に変換する必要があるかもしれないと思いますか??

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
4

1 に答える 1

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

サンプル Fiddle デモ

于 2013-02-22T13:56:18.860 に答える