Hola guillox:
Creo que estás tratando de implementar el operador LIMIT de MySQL cierto??? lamentablemente SQL Server no maneja tal operador, aunque con algunas adecuaciones podrías hacer algo parecido. Dale un vistazo a la función ROW_NUMBER(), esta te sirve entre muchas otras cosas para enumerar cada uno de tus registros, de tal manera que mediante una subconsulta puedes obtener lo que necesitas. Para el ejemplo voy a considerar que tus registros los estás ordenando por el campo EDAD, para enumerar cada renglón.
Código SQL:
Ver originalDECLARE @Tabla TABLE (nombre VARCHAR(20), edad INT)
INSERT INTO @Tabla VALUES ('Pablo', 10)
INSERT INTO @Tabla VALUES ('German', 14)
INSERT INTO @Tabla VALUES ('Nicolas', 15)
INSERT INTO @Tabla VALUES ('Ariel', 15)
INSERT INTO @Tabla VALUES ('Alexis', 17)
INSERT INTO @Tabla VALUES ('Joel', 17)
INSERT INTO @Tabla VALUES ('Sebastian', 18)
INSERT INTO @Tabla VALUES ('Matias', 19)
INSERT INTO @Tabla VALUES ('Cristian', 19)
INSERT INTO @Tabla VALUES ('Patricio', 19)
SELECT * FROM (
SELECT ROW_NUMBER() OVER(ORDER BY T1.edad) rownumber, T1.* FROM @Tabla T1) T2
WHERE T2.rownumber >= 4 AND T2.rownumber <= 7
La idea es básicamente la misma que la que comenta el compañero Libra al crear una tabla Temporal con IDENTITY, pero en un solo select, sin crear tablas adicionales.
Checa esta líga, ahí encontrarás información sobre el operador row_number que te podrá servir.
http://msdn.microsoft.com/es-es/library/ms186734.aspx
Saludos
Leo.