Dvě možnosti:
select
group_concat(houses), count(*), city
from
Table1
group by city;
nebo
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;
- vidět je pracovat naživo v sqlfiddle
Není to přesně jako váš výstup, ale informace v něm jsou stejné. Databáze nejsou od toho, aby data pěkně formátovaly. To by mělo být provedeno v aplikační vrstvě.