Två möjligheter:
select
group_concat(houses), count(*), city
from
Table1
group by city;
eller
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;
- se dem arbeta live i en sqlfiddle
Det är inte exakt som din produktion, men informationen i den är densamma. Databaser är inte till för att formatera data snyggt. Detta bör göras i applikationslagret.