Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Bases de datos > Firebird e Interbase
Registrarse FAQ Miembros Calendario Guía de estilo Buscar Temas de Hoy Marcar Foros Como Leídos

 
 
Herramientas Buscar en Tema Desplegado
  #5  
Antiguo 28-01-2010
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 26
guillotmarc Va por buen camino
Cita:
Empezado por Ricardojosep Ver Mensaje
Hola sierraja, también puedes hacer algo como esto...

Código SQL [-]select avg(col2) from (select col2 from tabla rows 3);


Lo de guillotmarc es una muy buena solución, no conocía el select first...

Saludos!!
Algo parecido a esto fue lo primero que me vino a la cabeza. Pero estas consultas derivadas (creo que se llaman), es decir hacer un select sobre un select en lugar de sobre una tabla, solo funciona a partir de Firebird 2.1. Y @sierraja no nos ha dicho con qué versión de Firebird trabaja.

Respecto al FIRST, es lo mismo que el ROWS, solo que se pone a continuación de SELECT y no al final de la consulta. De nuevo he utilizado el FIRST, porqué este funciona en todas las versiones de Firebird, mientras que el ROWS solo funciona en Firebird 2.0 para arriba.

Finalmente, fijate @ricardojosep que @sierraja nos ha pedido los últimos tres registros, pero tu consulta hace la media de los tres primeros (y ya es mucho suponer que sean los tres primeros, puesto que si no le marcamos ninguna ordenación, el motor puede escoger el orden y los tres registros que primero le vengan a mano, y técnicamente seguirá siendo igual de correcto).

Para especificar que queremos los tres últimos registros hay que poner forzosamente un order by, es decir, proporcionar un campo sobre el que se pueda especificar quienes van primeros y quienes últimos.

Saludos.

Última edición por guillotmarc fecha: 28-01-2010 a las 17:44:29.
Responder Con Cita
 


Herramientas Buscar en Tema
Buscar en Tema:

Búsqueda Avanzada
Desplegado

Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Microsoft paga seis mil millones de dólares por una empresa modesta semptrion Noticias 5 27-05-2007 16:37:56
Arreglo de Registros, con arreglos de Registros(Dinamico) PiornoCKA&G Varios 4 05-01-2007 08:53:30
por que duplicidad de registros con clientdataset sin ingresar registros ...mysql Arturo MySQL 3 05-09-2006 18:39:37
Seis Mil Casimiro Noteví La Taberna 17 18-07-2006 23:05:57
Como eliminar los registros de hace seis horas salvica SQL 4 23-08-2004 19:02:44


La franja horaria es GMT +2. Ahora son las 22:06:30.


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