Club Delphi  
    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-01-2007
Avatar de Luis M.
[Luis M.] Luis M. is offline
Miembro Premium
 
Registrado: sep 2004
Ubicación: Ripollet - Barcelona
Posts: 212
Poder: 20
Luis M. Va por buen camino
SP en Firebird 2, localizar el valor más alto

Saludos.

Utilizo D7 ,Firebird 2, MDO e IB Expert.
Tabla: Departamentos.
Campo: Codigo VARCHAR(3)
Los datos se almacenan como '001','002','003', etc.
Quisiera crear un SP o un Disparador(según sea lo mejor), que me
devolviese el código con el valor más alto.
He empezado hace poco con firebird y estoy muy verde en el tema

Gracias por vuestra colaboración.
Luis M.
Responder Con Cita
  #2  
Antiguo 23-01-2007
Avatar de ContraVeneno
ContraVeneno ContraVeneno is offline
Miembro
 
Registrado: may 2005
Ubicación: Torreón, México
Posts: 4.738
Poder: 23
ContraVeneno Va por buen camino
Código SQL [-]
select max(Codigo) from Departamentos

__________________

Responder Con Cita
  #3  
Antiguo 23-01-2007
Avatar de Luis M.
[Luis M.] Luis M. is offline
Miembro Premium
 
Registrado: sep 2004
Ubicación: Ripollet - Barcelona
Posts: 212
Poder: 20
Luis M. Va por buen camino
Gracias por responder.

Ese era el código que ponia, pero no me funcionaba
me salia el error de "multiple rows in singleton select".
Extraño porque el codigo era primary key y no hay duplicados.
Al final he tenido que desistalar el IB EXPRES y Firebird, borrar toda referencia
y volverlo a instalar.
Ahora funciona bien.
Quizas fue el cambio de firebird 1.53 al 2, no lo se...

Se puede hacer algo así:
Código SQL [-] select max(:campo) from :dataset into :ultimo;

Es para no tener que hacer un SP por cada tabla.

Muchas gracias.
Luis M.
Responder Con Cita
  #4  
Antiguo 24-01-2007
Avatar de jwmoreira
jwmoreira jwmoreira is offline
Miembro
 
Registrado: jun 2004
Posts: 83
Poder: 20
jwmoreira Va por buen camino
Revisa en los hilos acerca de EXECUTE STATEMENT.

Saludos,
Jorge.
Responder Con Cita
  #5  
Antiguo 24-01-2007
Avatar de Luis M.
[Luis M.] Luis M. is offline
Miembro Premium
 
Registrado: sep 2004
Ubicación: Ripollet - Barcelona
Posts: 212
Poder: 20
Luis M. Va por buen camino
Thumbs up Ok

Era lo que necesitaba.
Me funciona de maravilla.
Muchas gracias por tu ayuda.
Luis M.
Responder Con Cita
  #6  
Antiguo 26-01-2007
Avatar de Zeta
Zeta Zeta is offline
Miembro
 
Registrado: feb 2005
Posts: 215
Poder: 20
Zeta Va por buen camino
¿No será que querés saber el número de CÓDIGO siguiente para crear un nueva entrada CÓDIGO e introducir el nuevo registro? Para eso deberías utilizar un generador.

POr otra parte, si CÓDIGO es un generador (valor autoincremental) y querés saber el valor que sigue tenés que usar:

Código SQL [-]
SELECT GEN_ID(AGenerator, 1) from RDB$DATABASE;

Donde "AGenerator" es el nombre del generador (con IBExpert lo creas rápido y fácil), "1" es el salto (si pongo dos me daría dos números más, puede ser negativo también si mal no recuerdo) y para obtener el valor corriente cambias el "1" por el "0".

Igualmente buscá por el foro que seguramente encuentras más.


saludos
__________________
And I'd like an hour on the holodeck with Seven of Nine.
Responder Con Cita
  #7  
Antiguo 27-01-2007
Avatar de Luis M.
[Luis M.] Luis M. is offline
Miembro Premium
 
Registrado: sep 2004
Ubicación: Ripollet - Barcelona
Posts: 212
Poder: 20
Luis M. Va por buen camino
Hola Zeta.
Así es, es para incrementar los códigos.
Pero el generador no me sirve, los códigos no van siempre consecutivos.
Los incremento como referencia para el cliente, pero el cliente los puede
introducir del 0 al 100, del 300 al 500, etc.
Además hay códigos que pueden estar repetidos porque pueden pertenecer
a departamentos distintos.
Ejemplo:
Ruta->'001' -> departamento->'01'
Ruta->'001' -> departamento->'02'
Un problema que encuentro a los generadores (corríjanme si estoy equivocado) es este:
último código->'5'.
Nuevo registro-> generador->'6'.
Cancelo el nuevo registro.
Nuevo registro->generador->'7', cuando debiera de ser '6'.
Muchas gracias por tu información y ayuda.
Luis M.
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
Procedimieto para averiguar el valor de un generador en firebird Mauro® Conexión con bases de datos 4 15-12-2006 02:09:05
Localizar datos con Firebird joanajj Firebird e Interbase 5 06-06-2006 01:11:42
Alto de tabla D-MO HTML, Javascript y otros 16 18-05-2006 01:41:07
¿Como recorrer la culumna de un dbgrid y hallar el valor mas alto? ANXO OOP 3 12-04-2006 21:20:51
Saber el campo con valor mas alto ilichhernandez Conexión con bases de datos 2 10-11-2005 03:00:44


La franja horaria es GMT +2. Ahora son las 02:14:26.


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
Copyright 1996-2007 Club Delphi