Hola
No uso SQL Server, pero imagino que un procedimiento almacenado será más rápido que no esa subconsulta. Es decir, hacer la consulta que te retorne todos los registros pero sólo "envías" a partir del octavo resultado (que puedes controlar con una sencilla variable local).
Digo que imagino que será más rápido e eficiente dado que por cada registro estás haciendo la subconsulta, con el SP no hay subconsulta.
|