У меня есть запрос MySQL, который производит этот вывод, упорядоченный так:

Вместо этого я хотел бы, чтобы вывод упорядочился следующим образом: 
Я не уверен, как написать запрос, чтобы он упорядочивал данные так, как мне нужно.Мне нужны данные, отсортированные по дате DESC, затем по времени DESC, но также для объединения общих элементов markers_name вместе.(Я хочу, чтобы они объединялись для каждой даты).
Этот запрос я использую:
SELECT markers.name AS markers_name,
conditions.time AS conditions_time,
conditions.date AS conditions_date,
station.name AS station_name
FROM markers, conditions, users
WHERE conditions.markers_id = markers.id
AND (conditions.station_id = station.id)
ORDER BY date DESC, markers.name, time DESC
LIMIT 100
(PS Я не указывал имя станции в моих таблицах вывода, но онидействительно появляются в моем реальном запросе.)
РЕДАКТИРОВАТЬ: Я добавил еще несколько таблиц, чтобы попытаться объяснить проблему лучше.Обратите внимание, что запрос на самом деле не возвращается.Я просто добавил это, чтобы помочь с разговором.У каждого блока есть общая дата.
Вот вывод после того, как я попробовал ORDER BY date DESC, markers.name DESC, время DESC 
И вот мой желаемый вывод:

Сравните «Чанк 4» на двух выходах.Верхняя таблица порядков по названию по убыванию.Это не желательно.Marker_name 'd' содержит новейшую информацию, поэтому я хочу, чтобы она была первой.«С» имеет следующую новейшую информацию.«F» имеет самую старую информацию.Следующая таблица показывает порядок, который мне нужен.
Надеюсь, это лучше прояснит проблему.Кто-нибудь может помочь?
РЕДАКТИРОВАТЬ 2 Я попробовал этот предложенный ответ: "ПОРЯДОК ПО ДАТЕ DESC, времени DESC, markers.name DESC", но это не сработало.

Обратите внимание, что фрагмент 3 упорядочен по времени.Строки 'e' и 'b' не сгруппированы вместе.