Аналитика - ваш друг в этом случае:
SQL> CREATE TABLE t (NAME VARCHAR2(32), v1 INTEGER, v2 INTEGER, v3 INTEGER);
Table created
SQL> INSERT INTO t VALUES ('name1',1,1,1);
1 row inserted
SQL> INSERT INTO t VALUES ('name2',1,1,2);
1 row inserted
SQL> INSERT INTO t VALUES ('name3',2,2,11);
1 row inserted
SQL> INSERT INTO t VALUES ('name4',2,12,2);
1 row inserted
SQL> INSERT INTO t VALUES ('name5',3,3,8);
1 row inserted
SQL> INSERT INTO t VALUES ('name6',3,3,2);
1 row inserted
SQL> SELECT NAME, v1, v2, v3
FROM (SELECT NAME, v1, v2, v3
, MAX(v2) OVER(PARTITION BY v1) mv2
, MAX(v3) OVER(PARTITION BY v1,v2) mv3
FROM t)
WHERE v2 = mv2
AND v3 = mv3
ORDER BY v1;
NAME V1 V2 V3
------ -- -- --
name2 1 1 2
name4 2 12 2
name5 3 3 8