oracle8.1.6 select g.rel_type, g.group_rel_id, acs_object_type.pretty_name(g.rel_type) as rel_type_pretty_name, s.segment_id, s.segment_name, acs_rel_type.role_pretty_plural(rel_types.role_two) as role_pretty_plural, acs_rel_type.role_pretty_name(rel_types.role_two) as role_pretty_name, rels.num_rels, case when valid_types.group_id = null then 0 else 1 end as rel_type_valid_p from group_rels g, rel_segments s, acs_rel_types rel_types, (select rel_type, count(*) as num_rels from group_component_map where group_id = :group_id and group_id = container_id group by rel_type UNION ALL select rel_type, count(*) as num_rels from group_approved_member_map where group_id = :group_id and group_id = container_id group by rel_type) rels, rc_valid_rel_types valid_types where g.group_id = s.group_id(+) and g.rel_type = s.rel_type(+) and g.rel_type = rels.rel_type(+) and g.rel_type = rel_types.rel_type and g.group_id = :group_id and g.group_id = valid_types.group_id(+) and g.rel_type = valid_types.rel_type(+) order by lower(g.rel_type)