Solução mais simples:
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>
Se você tiver 11gR2, poderá usar a nova função LISTAGG(), mas caso contrário, é simples o suficiente para envolver a instrução acima em um SELECT que concatena as colunas NAME e NICKNAME.