Powinieneś zrobić to db zamiast swojej aplikacji:
select t.id_prfx, max(t.id_num) as latest_num from
(select substring(id, 1, 3) as id_prfx,
cast(substring(id,4) as integer) as id_num) t
group by id_prfx
W ten sposób otrzymasz tabelę wyników, w której uzyskasz najwyższy numer części dla każdego prefiksu.
Jeśli naprawdę chcesz tylko przedrostków „ABC”, to:
select max(cast(substring(id,4) as integer)) as max_num from table
where id LIKE 'ABC%'