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 Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 28-04-2011
arrayman arrayman is offline
Miembro
 
Registrado: abr 2006
Posts: 55
Poder: 19
arrayman Va por buen camino
¿como obtener id del registro recien insertado?

Buenas, Pues eso tengo una aplicacion que utiliza dbexpress para conectarse con firebird actualmente uso procedimientos almacenados como este
Código SQL [-]
CREATE OR ALTER PROCEDURE SP_GEN_CCLIENTES_ID 
returns (ID Integer)
AS 

begin
  ID=GEN_ID(GEN_CCLIENTES_ID,1);
  SUSPEND;
end

para obtener una clave unica y usarla en las inserciones.
pero pienso que debe existir otra forma en la que puedas averiguar que
id asigno un triger con un codigo similar al anterior

la principal desventaja de mi sistema es que tiende a generar huecos.

en fin si alguien lo hace de otro modo ... estaria bien conocerlo

un saludo.
Responder Con Cita
  #2  
Antiguo 28-04-2011
Avatar de oscarac
[oscarac] oscarac is offline
Miembro Premium
 
Registrado: sep 2006
Ubicación: Lima - Perú
Posts: 2.010
Poder: 20
oscarac Va por buen camino
y porque genera los huecos?
cual es el motivo?
__________________
Dulce Regalo que Satanas manda para mi.....
Responder Con Cita
  #3  
Antiguo 28-04-2011
Avatar de Chris
[Chris] Chris is offline
Miembro Premium
 
Registrado: abr 2007
Ubicación: Jinotepe, Nicaragua
Posts: 1.678
Poder: 19
Chris Va por buen camino
Usa la clausula RETURNING.
__________________
Perfil Github - @chrramirez - Delphi Blog - Blog Web
Responder Con Cita
  #4  
Antiguo 29-04-2011
arrayman arrayman is offline
Miembro
 
Registrado: abr 2006
Posts: 55
Poder: 19
arrayman Va por buen camino
creo que si metes el codigo en un triguer habra menos posibilidad de fracaso en la insercion pues supongo que saltara cuando el registro se ha validado y
va a ser insertado. con mi sistema yo tengo que reservar el id antes de grabar y si la insercion falla el codigo ya ha sido reservado si el usuario decide no volver a intentarlo o simplemente pulso donde no era y cancela el hueco esta.
no es gran diferencia, tb es curiosidad.

gracias mirare el link de returning en cuanto pueda ahora me voy a sobar
que es tarde y mañana es mañana.
Responder Con Cita
  #5  
Antiguo 29-04-2011
arrayman arrayman is offline
Miembro
 
Registrado: abr 2006
Posts: 55
Poder: 19
arrayman Va por buen camino
esta bien no pude resistirme y lo mire,

desconocia esa información, muy bueno pero la verdad que yo hago las inserciones via tclientdataset, es decir las hace el por mi.
no se si habra alguna opcion de configuración para que genere ese tipo
de sentencia y me devuelva la primarykey, si no se pierde en comodidad
pero me viene genial para los casos en que lo tenga que hacer a mano.

muchas gracias.
Responder Con Cita
  #6  
Antiguo 29-04-2011
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 36
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Cita:
la principal desventaja de mi sistema es que tiende a generar huecos.
Los generadores se diseñaron para garantizar la unicidad en entornos multiusuario y no es relevante que sean consecutivos. Las 'brechas' numéricas son
muy normales con su uso.
El tema de los 'huecos' se presenta por ejemplo cuando: El usuario A obtiene el identificador 500, seguidamente el usuario B recibe el 501,
el C el 502, etc. Entonces el usuario A decide abortar haciendo un rollback, el generador continuará la secuencia sin importar la posición 500.

Para hacer códigos consecutivos podés incrementar un campo mediante un trigger y usar un procedimiento almacenado para obtener el próximo código.

Por ejemplo:
Código SQL [-]
SET TERM ^;
CREATE TRIGGER TABLA_CODIGO_AI FOR TABLA_CODIGO ACTIVE AFTER INSERT POSITION 0
AS
BEGIN
  UPDATE TABLA_CODIGO SET NUM_CODIGO = NUM_CODIGO + 1;
END^

CREATE PROCEDURE SP_PROXIMOCODIGO RETURNS (PROXCOD CHAR(8))
AS
DECLARE VARIABLE NUMERO INTEGER;
BEGIN
  SELECT NUM_CODIGO FROM TABLA_CODIGO INTO NUMERO;
  NUMERO = NUMERO + 1;
  PROXCOD = LPAD(TRIM(CAST(NUMERO AS VARCHAR(8))), 8, '0');
END^
SET TERM ;^
El procedimiento te devolverá el próximo siguiente código. (00000001,00000002,00000003,..)

Un saludo.
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....

Última edición por ecfisa fecha: 29-04-2011 a las 03:44:52.
Responder Con Cita
Respuesta



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
Cómo obtener el título del cd insertado? unreal4u API de Windows 4 09-07-2007 22:32:13
Obtener ID_Direccion recien insertado Durbed SQL 8 19-08-2005 02:57:58
¿Como leer el registro recien incluido? sitrico Conexión con bases de datos 6 30-07-2004 13:44:06
Obtener ClaveMaestra del registro insertado. jplj Conexión con bases de datos 11 20-05-2004 00:18:33
Obtener el último registro insertado mutant09 SQL 3 04-05-2004 20:59:21


La franja horaria es GMT +2. Ahora son las 15:45:39.


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