Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   seleccionar los ultimos registros de una tabla (https://www.clubdelphi.com/foros/showthread.php?t=68728)

ingabraham 02-07-2010 17:26:38

seleccionar los ultimos registros de una tabla
 
necesito seleccionar los ultimos 8 registros insertados en una tabla
algo asi:

Código SQL [-]
select * from tabla first rows 8
pero me aparecen los primeros
quiero los ultimos.

en firebird.

ElDioni 02-07-2010 17:45:56

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?
Código SQL [-]
select * from tabla Last rows 8

Un saludo.

Neftali [Germán.Estévez] 02-07-2010 18:34:26

¿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:)

cloayza 02-07-2010 18:45:54

Podria ser:

Sintaxis:
Cita:

SELECT ... ROWS <expr1> [TO <expr2>]
Código SQL [-]
SELECT* FROM TABLA ROWS (SELECT COUNT(*) FROM TABLA)-7 TO (SELECT COUNT(*) FROM TABLA)

Saludos

Casimiro Notevi 02-07-2010 18:50:24

Habría que definir un campo para saber el orden, supongo
que tienes un campo fecha o código, o algo así.

Código SQL [-]
select first 8 tucampo
from tutabla
order by campofecha desc

ElDioni 02-07-2010 18:59:13

Deduzco de los tres últimos mensajes que mi propuesta es una burrada bastante grande, ¿no?.

Saludos.

Casimiro Notevi 02-07-2010 20:18:52

Cita:

Empezado por ElDioni (Mensaje 369006)
Deduzco de los tres últimos mensajes que mi propuesta es una burrada bastante grande, ¿no?.
Saludos.

No es una burrada, es que no puedes saber cuales son los últimos registros si no llevas algún control.

marcoszorrilla 02-07-2010 21:00:22

Puedes hacer primero un conteo y guardarlo en una variable.


Y luego:

Código SQL [-]
Select First 8 Skip Variable - 8 mis campos from mi tabla Order by ElQueSEa;
Un Saludo.

Caral 02-07-2010 21:07:04

Hola
De las soluciones mas simples, faciles y logicas que he visto en mucho tiempo.
Me gusto.
Saludos

cloayza 02-07-2010 21:27:25

Cita:

Empezado por marcoszorrilla (Mensaje 369019)
Puedes hacer primero un conteo y guardarlo en una variable.


Y luego:

Código SQL [-]
Select First 8 Skip Variable - 8 mis campos from mi tabla Order by ElQueSEa;
Un Saludo.

Como lo indico en mi solucion, la "Variable" podria ser:

Código SQL [-]
Select First 8 Skip (SELECT COUNT(*) FROM TABLA) - 8 mis campos from mi tabla Order by ElQueSEa;

Saludos...

Casimiro Notevi 02-07-2010 22:00:59

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".

Neftali [Germán.Estévez] 03-07-2010 11:21:54

Cita:

Empezado por ElDioni (Mensaje 369006)
Deduzco de los tres últimos mensajes que mi propuesta es una burrada bastante grande, ¿no?.

No necesariamente. ;)
Si existe el LAST es la mejor opción; En otras bases de datos no existe, pero en FB lo desconozco.

Casimiro Notevi 03-07-2010 13:04:47

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.

Código SQL [-]
select first 8 tucampo
from tutabla
order by campodelgenerador desc

Caral 03-07-2010 16:32:42

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

Caral 03-07-2010 16:55:29

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:

Código Delphi [-]
QRBancoGen:=TQRBancoGen.Create(self);
QRBancoGen.ADOQuery1.SQL.Add(' SELECT DISTINCTROW BancoNac.CodTransac,  Last(BancoNac.IdTramsac) AS ÚltimoDeIdTramsac, '+
                            ' BancoNac.TipoTransac, BancoNac.FechaTransac, BancoNac.Descripcion, '+
                            ' Sum(BancoNac.Retiros) AS [Suma De Retiros], Sum(BancoNac.Depositos) AS [Suma De Depositos], '+
                            ' Last(BancoNac.SaldoTotal) AS SaldoTotal FROM BancoNac');
QRBancoGen.ADOQuery1.SQL.Add(' WHERE BancoNac.FechaTransac >= #'+DateToStr(DTP1.Date)+ '# AND  BancoNac.FechaTransac <= # '+DateToStr(DTP2.Date)+'#');
QRBancoGen.ADOQuery1.SQL.Add(' GROUP BY BancoNac.CodTransac, BancoNac.TipoTransac, BancoNac.FechaTransac, BancoNac.Descripcion ');
QRBancoGen.ADOQuery1.SQL.Add(' ORDER BY Last(BancoNac.IdTramsac), BancoNac.FechaTransac ASC');
QRBancoGen.ADOQuery1.Open;

En Firebird:
Dando el mismo resultado:

Código Delphi [-]
QRBancoGen:=TQRBancoGen.Create(self);
QRBancoGen.ADOQuery1.SQL.Add(' SELECT DISTINCT BancoNac.CodTransac,  Max(BancoNac.IdTramsac) AS UltimoDeIdTramsac, BancoNac.TipoTransac, '+
                              ' BancoNac.FechaTransac, BancoNac.Descripcion, '+
                              ' Sum(BancoNac.Retiros) AS SumaDeRetiros, Sum(BancoNac.Depositos) AS SumaDeDepositos, '+
                              '  Max(BancoNac.SaldoTotal) AS SaldoTotal FROM BancoNac ');
QRBancoGen.ADOQuery1.SQL.Add(' WHERE BancoNac.FechaTransac >= :fech1 AND  BancoNac.FechaTransac <= :fech2');
QRBancoGen.ADOQuery1.SQL.Add(' GROUP BY BancoNac.CodTransac, BancoNac.TipoTransac, BancoNac.FechaTransac, BancoNac.Descripcion ');
QRBancoGen.ADOQuery1.SQL.Add(' ORDER BY Max(BancoNac.IdTramsac), BancoNac.FechaTransac ASC');
QRBancoGen.ADOQuery1.Params[0].Value:= DateToStr(DTP1.Date);
QRBancoGen.ADOQuery1.Params[1].Value:= DateToStr(DTP2.Date);
QRBancoGen.ADOQuery1.Open;

Tal vez ayude a enterder algo mas, no se.
Saludos

slnit 21-02-2015 01:07:09

SELECT TOP 8 FROM TUTABLA ORER BY FECHA DESC. Saludos

Casimiro Notevi 21-02-2015 01:08:33

Cita:

Empezado por slnit (Mensaje 489087)
Saludos

Bienvenido a clubdelphi, como siempre aconsejamos a los nuevos, no olvides leer nuestra guía de estilo, gracias por tu colaboración :)


Recuerda poner los tags al código fuente, ejemplo:



Gracias :)


La franja horaria es GMT +2. Ahora son las 03:03:51.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi