¿Estás seguro de que al cerrar o abrir una u otra ventana no estás, también, cerrando o cambiando algo en la base de datos? Lo digo porque muchas veces ponemos algo en un evento "onClose" y luego se nos olvida. También hay que tener en cuenta que hay muchos componentes implicados en una consulta. Un TSQLTransaction puesto donde no es puede cerrarte una conexión o hacerte un roll-back si se destruye antes de tiempo, por ejemplo.
La verdad, no sé qué comentarte, salvo decirte que todos los componentes implicados en el trabajo de la base de datos deberían estar en otro objeto fuera de las ventanas (por ejemplo, en un TData).
|