Anda memang harus menggunakan php untuk menyelesaikan ini. Tetapi karena sebagian besar sistem saat ini memisahkan logika dari tampilan, saya hanya akan menggunakan satu pass dan bukan (NUMBER OF DAYS + 1) SELECT, dan menyiapkan array yang dapat saya gunakan kembali nanti untuk tampilan saya.
$query = "SELECT DATE_FORMAT(date, '%M %D') as d, name FROM yourtable ORDER BY date";
$foo=array();
$result = mysql_query($query);
while($row = mysql_fetch_assoc($result)) {
//some logic to test if it's safe to add the name
$foo[$row['d']][]=$row['name'];
}
Dan kemudian ketika saya membutuhkannya (melalui template atau "tampilan" Anda)
foreach($foo as $date => $events) {
echo $date . ":\n\t";
echo implode(",\n\t", $events);
echo "\n";
}
sehingga sesuai dengan format yang Anda atur sendiri.
Semoga membantu