A PL/SQL tem um recurso conhecido como SQL dinâmico que permite que você crie e execute arbitrariamente as instruções SQL, bem como blocos PL/SQL em tempo de execução. Se você executar um bloco PL/SQL dinamicamente, que contenha um erro de compilação, esse erro será levantado em tempo de execução e poderá ser capturado por um handler de exceção.
Se ocorrer um erro, uma exceção é levantada. Quando isso acontecer, o controle passa para o handler de exceção, que é uma seção separada do programa. Isso separa o tratamento de erro do restante do programa, o que torna a lógica do programa mais fácil de entender. Isso também assegura que todos os erros serão interceptados.
http://dc307.4shared.com/img/MM2hhYNA/preview.html