![]() |
seleccionar los ultimos registros de una tabla
necesito seleccionar los ultimos 8 registros insertados en una tabla
algo asi: pero me aparecen los primeros quiero los ultimos. en firebird. |
No manejo firebird, pero viendo lo que pones, si dices que te muestra los 8 primeros registros, me voy a tirar a la piscina sin saber si hay agua, ¿has probado a poner los siguiente?
Un saludo. |
¿Y si haces el FIRST 10, pero le pones el ORDER BY al contrario?
Si es que tienes algun campo por el que poder ordenar al contrario (Clave primaria, Fecha,... :confused:) |
Podria ser:
Sintaxis: Cita:
Saludos |
Habría que definir un campo para saber el orden, supongo
que tienes un campo fecha o código, o algo así.
|
Deduzco de los tres últimos mensajes que mi propuesta es una burrada bastante grande, ¿no?.
Saludos. |
Cita:
|
Puedes hacer primero un conteo y guardarlo en una variable.
Y luego: Un Saludo. |
Hola
De las soluciones mas simples, faciles y logicas que he visto en mucho tiempo. Me gusto. Saludos |
Cita:
Saludos... |
El problema cloayza es que así se trae los últimos registros según el orden "elquesea", pero esos no tienen por qué ser los últimos que se han guardado en la base de datos. Todo depende de qué es "elquesea".
|
Cita:
Si existe el LAST es la mejor opción; En otras bases de datos no existe, pero en FB lo desconozco. |
Es que el 'last' es el último de select que se haya hecho, pero para saber realmente el orden de grabación de los registros habría que poner un control, que puede ser perfectamente un campo que saque el número de un generador, por ejemplo, y cada vez que se haga un post (ya sea insertando o modificando) le asigne el número siguiente que toque.
Así puede hacerse el select por ese campo.
|
Hola
En Firebird existe el last, pero no para estos fines. Lo que se puede usar, sabiendo como, es MAX(). Tenia un problema similar en una consulta en Access que contenia algunos Last(), los cambie por Max() y me da el dato correcto, exacto. Saludos |
Hola
En este reporte en especial es donde tube el problema. Se que es una sentencia sql sencilla pero cuando se cambia de access a Firebird se complica por desconocimiento, en mi caso es asi. El asunto esta en el orden del IdTransac, que es el que define todo. En Access:
En Firebird: Dando el mismo resultado:
Tal vez ayude a enterder algo mas, no se. Saludos |
SELECT TOP 8 FROM TUTABLA ORER BY FECHA DESC. Saludos
|
Cita:
Recuerda poner los tags al código fuente, ejemplo: ![]() Gracias :) |
La franja horaria es GMT +2. Ahora son las 21:52:40. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi