Solution la plus simple :
SQL> select * from t69
2 /
NAME NICKNAME ID
---------- ---------- ----------
Joe Joey 14
Joe 14
Michael 15
Mick 15
Mickey 15
SQL> select max(name) as name
2 , max(nickname) as nickname
3 , id
4 from t69
5 group by id
6 /
NAME NICKNAME ID
---------- ---------- ----------
Joe Joey 14
Michael Mickey 15
SQL>
Si vous avez 11gR2, vous pouvez utiliser la nouvelle fonction LISTAGG(), mais sinon, il est assez simple d'envelopper l'instruction ci-dessus dans un SELECT qui concatène les colonnes NAME et NICKNAME.