FTP | CCD | Buscar | Trucos | Trabajo | Foros |
|
Registrarse | FAQ | Miembros | Calendario | Guía de estilo | Temas de Hoy |
|
Herramientas | Buscar en Tema | Desplegado |
|
#1
|
|||
|
|||
Gracias a todos por responder.
La idea que yo tengo es la que ha expuesto gluglu. El tema de un Identificador también lo tengo en cuenta, lo que pasa es que el identificador siempre lo utilizo cuando es necesario, es decir, que el cliente no tiene que meter un código identificativo. El problema de los identificadores (para mí) es que en la aplicación que estoy haciendo, cuando me devuelve un dato, me devuelve el identificador + el campo asignado, el problema es que yo no quiero que me devuelva el identificador, sino el código. Una cosa que no entiendo es que en el flamerobin cuando hago un select de la tabla me la devuelve tal y como se ha metido, y yo me pregunto, no tendrá el firebird algún dato guardado que dice el orden en el que se ha metido la información? Gracias de nuevo, pero si alguien sabe alguna manera de poder realizarlo le agradecería que lo comentase. |
#2
|
||||
|
||||
No creo que un motor de BBDD grabe dentro de la propia tabla el dato que estás pidiendo. Si de hecho lo graba en modo secuencial, según orden de introducción, para qué grabar esa información adicional si ya de hecho está almacenado en forma secuencial.
Por eso, al realizar un Select sin más (sin order by u otra sentencia ordenatoria) te devuelve los registros en el orden secuencial en los que fueron introducidos. El problema es que, al menos que yo conzoca, no existe sentencia en SQL para poder seleccionar los últimos registros de un Select (los primeros si). SI utilizas un 'supuesto' truco para ordenar en orden inverso para acceder en vez de a los primeros, a los últimos registros, ya estamos de nuevo imponiendo un 'orden' y se vuelve a fastidiar el asunto. Por ello, la única manera que yo veo es de realizar el Select y en Delphi acceder mediante Last al último registro. Otra cosa diferente sería que añadieras cualquier campo adicional a tu tabla. Podría ser precisamente un código incremental según un generador, o simplemente un campo TimeStamp por ejemplo que te guarde la fecha y la hora. De esta manera si que se podría hacer un Select con un order descendente y acceder al dato que solicitas. Pero claro, ese planteamiento es diferente, tienes que añadir un nuevo campo a tu tabla y realizar toda una implementación para controlar ese campo. Cita:
__________________
Piensa siempre en positivo ! |
#3
|
|||
|
|||
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. |
#4
|
|||
|
|||
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 |
#5
|
|||
|
|||
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. |
#6
|
|||
|
|||
Cita:
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. |
#7
|
|||
|
|||
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. |
|
|
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 |
|