Ver Mensaje Individual
  #13  
Antiguo 25-10-2007
afxe afxe is offline
Miembro
 
Registrado: jul 2004
Ubicación: Malaga-España
Posts: 273
Reputación: 20
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