Aunque me llama la atencion del motivo de insertar muchas veces los mismo datos, pues no acabo de enteder el por qué

, a no ser que ciertos campos cambien, excepto los campos primarios, pero si los datos no cambian en ningun momento, entonces es en vano estar modificando a cada rato...
Bueno.. en MySQL existe la sentencia
REPLACE que funciona exactamente como INSERT, excepto que si un valor de la tabla tiene el mismo valor que un nuevo registro para un índice PRIMARY KEY o UNIQUE , el antiguo registro se borra antes de insertar el nuevo.

Yo no uso Firebird pero supongo que debe existir algo similar aunque viendo el link del amigo
gluglu veo que existe el comando
MERGE en firebird supongo que debe ser similar.

Saludos...
