Зависи коя версия използвате, но аз имах същия проблем и ->distinct() работи за мен.
Doctrine_Query::create()
->select('rec.city')->distinct()
->from('Records rec')
->where("rec.state = '$state'")
->execute();