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

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 23-10-2007
altp altp is offline
Miembro
 
Registrado: sep 2003
Posts: 131
Poder: 23
altp Va por buen camino
Gracias gluglu por responder.

Flamerobin es un programa gestor de Firebird. Lo puedes obtener de www.Firebird.org.

Si no hay otra forma gracias de nuevo.
Responder Con Cita
  #2  
Antiguo 23-10-2007
Mick Mick is offline
Miembro
 
Registrado: may 2003
Posts: 405
Poder: 24
Mick Va por buen camino
NO se puede usar un last para recoger el ultimo registro insertado. No existe el concepto de ultimo registro en este tipo de bases de datos, y hacer eso un bug.

La bases de datos guardan los ultimos registros insertados en el orden que le de la gana si es necesario en el medio al principio o donde sea que tenga "huecos libres".

De modo que hacer un last no necesariamente va a devolver el ultimo registro insertado, unas veces puede que si otras puede que no. Asi que hacer eso es garantia de caos total en el futuro.

Saludos
Responder Con Cita
  #3  
Antiguo 23-10-2007
altp altp is offline
Miembro
 
Registrado: sep 2003
Posts: 131
Poder: 23
altp Va por buen camino
Si lo que dice Mick es cierto, gracias a todos por intentar echarme una mano.

Pues si no queda otra, doy por cerrado el hilo.

Gracias nuevamente.
Responder Con Cita
  #4  
Antiguo 25-10-2007
Delfino Delfino is offline
Miembro
 
Registrado: jul 2003
Ubicación: Madrid
Posts: 974
Poder: 23
Delfino Va por buen camino
Cita:
Por ello, la única manera que yo veo es de realizar el Select y en Delphi acceder mediante Last al último registro.
Eso seria ralentizar mucho la aplicacion, un last no lo hace ni el mismo DBGrid ni el MDODataset para saber el numero de filas pq es costoso, mejor hacer un Count(*)

Cuando no le pides al servidor q ordene por un campo, te los devuelve en el orden fisico en q han sido insertados los regitros, de alli q el Flamerobin te los devuelve asi, tb existe la clausula Rows q se ha introducido me parece a partir de la version 2.0, le dices q te devuelva el ultimo y asunto solucionado.
__________________
¿Microsoft? No, gracias..
Responder Con Cita
  #5  
Antiguo 25-10-2007
afxe afxe is offline
Miembro
 
Registrado: jul 2004
Ubicación: Malaga-España
Posts: 295
Poder: 22
afxe Va por buen camino
No es tan sencillo

Realmente es así, cuando se hace un select sin ORDER sale en el orden físico. Lo malo, es que cuando se eliminan registros, se marca el espacio como disponible, de forma que cuando se producen nuevos registros pueden entrar en estos huecos. Tengo una aplicación de contabilidad, en cuyo trigger BEFORE INSERT asigno la fecha y hora en la que se ha hecho el apunte (fecha y hora del servidor). Cuando hago un SELECT sin ORDER, las filas no aparecen ordenadas según este campo, cuando debería ser así, ya que indica la secuencialidad de entrada de registros (de hecho, fue necesario crear un índice por este campo para agilizar las consultas).

En definitiva... créate un campo DateTime (timestamp) o un nº secuencial con un generator y automantenido con gen_id en el Before Insert, y después puedes hacer la consulta con un DESC en el ORDER BY y usar la clausual ROWS 1... aunque si no permites borrados en esa tabla el orden físico se corresponderá con el orden de entrada... A lo mejor algún Guro de Firebird nos da la solución con algún campo interno de estos de RDB$yoquese y se puede ordernar por ahí...

Saludos.
Responder Con Cita
Respuesta


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
Devolver varios registro desde SP lucasarts_18 Oracle 2 27-12-2005 15:16:57
No guarda el ultimo registro Tecnic2 Conexión con bases de datos 3 01-09-2004 19:31:23
Ultimo registro ander Firebird e Interbase 3 18-03-2004 14:52:02
Obtener el último registro juanchi Conexión con bases de datos 2 06-02-2004 01:52:21
Ir al último registro de una tabla fortran Tablas planas 6 05-09-2003 16:36:02


La franja horaria es GMT +2. Ahora son las 20:16:09.


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