Você pode ajustar prontamente sua lógica para lidar com isso adicionando um espaço à string antes de procurar um espaço:
select substr(b.x_ids, 1, instr(b.x_ids || ' ', ' ', 1, 1) - 1)
from lookup_tab a join
external_tab b
on a.site_id = B.SITE_ID and a.zone_id = b.zone_id