Acho que simplificando a consulta você removeu a causa real do bug :-)
Qual versão do oracle você está usando? Oracle 10g ( 10.2.0.1.0 ) fornece:
create table parts (ptno number , ptnm number , catcd number);
create table CATEGORIES (catcd number);
select PTNO,PTNM,CATCD from PARTS
left join CATEGORIES on (CATEGORIES.CATCD=PARTS.CATCD);
Recebo ORA-00918:coluna definida de forma ambígua