Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   SQL (https://www.clubdelphi.com/foros/forumdisplay.php?f=6)
-   -   SQL top 10 (https://www.clubdelphi.com/foros/showthread.php?t=33206)

Gustavo Gowdak 29-06-2006 20:19:50

SQL top 10
 
Hola amigos tengo una consulta para hacerles, tengo una tabla en interbase de facturas de clientes, que quiero que la consulta me tire las 10 ultimas facturas ordenadas por fecha, como puedo hacer???

ContraVeneno 29-06-2006 22:51:52

Código SQL [-]
select first(10) factura
from facturas
order by fecha desc

marcoszorrilla 29-06-2006 23:08:32

Código SQL [-]
Select first 10 skip Count(*) - 10

No lo he probado.

Un Saludo.

vtdeleon 29-06-2006 23:33:17

Saludos

Hay que ver si lo que se desea es : Tener los ultimos registros en la tabla y que estos ultimos esten organizados por fecha. Lo habia entendido asi.

lbuelvas 30-06-2006 03:57:47

Hola foro, un gusto regresar a colaborar (y que me colaboren).

Bueno, estoy trabajando con firebird 1.5.2 y me lleve tamaña sorpresa al tratar de hacer un subquery para poder responder la pregunta de este hilo.

El codigo seria:

Código SQL [-]
select first 10 *
from factura 
order by numero_factura

Supongo que el identificador de la tabla es numero_factura, pero es posible que la numeracion de la facturacion no este en orden cronologico, y ese caso lo tengo con un cliente donde la factura 0001 es hecha el 10/10/2006 y la factura 0002 es hecha el 09/09/2006.

En vista de esa situacion me puse a hacer subconsultas y los resultados no fueron congruentes, pues lo que me mostro fue una lista con 5 registros pero de personas que empezaban los nombre por la letra A. Este es el codigo:

Código SQL [-]
select first 5 *
from predio
where id in  (select first 5 id
                 from predio
                 order by id
                )
order by nombre

Entonces sugeriria utilizar un procedimiento almacenado de la forma que presento a continuacion, es un ejemplo de una de mis bases de datos.

Código SQL [-]
SET TERM ^ ;

CREATE PROCEDURE SP_PRUEBA (
    cantidad integer)
returns (
    id_predio varchar(15))
as
begin
  for execute statement 'select first ' || (cast (cantidad as varchar(10))) || ' id ' ||
                        'from predio '  ||
                        'order by id '
                        into :id_predio
  do begin
    suspend;
  end
end^

SET TERM ; ^

y luego puedes hacer la consulta

Código SQL [-]
select *
from predio a
inner join  sp_prueba (3) b on (a.id = b.id_predio)
order by nombre

Como enredadito no ?

Espero que sea de utilidad o de ampliacion porque a mi la subconuslta no me funciono.


La franja horaria es GMT +2. Ahora son las 00:30:52.

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