Entendo que você pode especificar -> distinct () na instrução db_select para que ele retorne apenas valores distintos ao examinar TODOS os campos. Mas o que eu quero é retornar valores distintos apenas olhando para UM campo. Aqui está o meu código:
$event_table = db_select('my_table', 'e')
->distinct()
->orderBy('e.time', 'ASC');//ORDER BY
$event_table->join('node', 'n', 'e.nid = n.nid'); //JOIN node with events
$event_table->groupBy('e.time');//GROUP BY time
$event_table->fields('e')//SELECT the fields from events
->fields('n',array('type','status','title'))//SELECT the fields from node
->orderBy('e.time', 'ASC');//ORDER BY
$result_event_table = $event_table->execute();
$result_event_table = $result_event_table->fetchAllAssoc('time');
Suponha que eu queira que a coluna distinta seja e.nid. Você pensaria -> distinct ('e.nid') funcionaria, mas ainda retornaria valores distintos com base em todos os campos (ou seja, distintos (colunas1, coluna2, coluna3, etc).
db_select
a fazer o mesmo