Dwie możliwości:
select
group_concat(houses), count(*), city
from
Table1
group by city;
lub
select a.houses, a.city, noofhouses
from Table1 a
inner join (
select
count(*) as noofhouses, city
from Table1
group by city
) b on a.city = b.city
order by a.city, noofhouses desc, a.houses;
- zobacz, jak pracują na żywo w sqlfiddle
Nie jest dokładnie taki, jak twoje wyjście, ale zawarte w nim informacje są takie same. Bazy danych nie są po to, aby ładnie formatować dane. Należy to zrobić w warstwie aplikacji.