Hola,
Si el panorama son directorios,
Una idea sería un pool de conexiones y según el rango de fechas en la consulta, lanzar la SQL para cada tabla de cada directorio anual. Podrías meter los resultados de las Query en un Tdataset y después hacer un group by año.
|