mmm.. EAVS...Além das sugestões óbvias de realmente implementar um design, você pode conseguir o que deseja assim:
Select Min( Case When name = 'fname' Then value End ) As fname
, Min( Case When name = 'lname' Then value End ) As lname
, Min( Case When name = 'city' Then value End ) As city
From MyTable
Group By Id