Interbase - Como creo un campo autonumerico en interbase

 
Vista:

Como creo un campo autonumerico en interbase

Publicado por Misael (4 intervenciones) el 02/01/2003 03:31:36
como creo un campo autonumero en interbase
Valora esta pregunta
Me gusta: Está pregunta es útil y esta claraNo me gusta: Está pregunta no esta clara o no es útil
0
Responder

RE:Como creo un campo autonumerico en interbase

Publicado por Fabian (10 intervenciones) el 02/01/2003 13:31:43
Hola Misael:

Este Tip fue extraidos de los trucos para interbase del club delphi:
Un saludo y suerte. Espero que te sirva o te de una idea.

¿Cómo se implementa un campo Autoincremento en Interbase y SQL Server?

Para los que vienen de Paradox u otros sistemas similares al mundo C/S la primera pega que se encuentran es como genero un campo Autoincremento.

En SQL Server de Microsoft tenemos unos campos especiales, llamados Entity, que suplen esta función.

En Interbase es algo más laborioso, (va muy bien usar una herramienta aftercase):

Creamos un generador:

SET GENERATOR GenIdCliente TO 1
(aquí el numero lo escogemos, claro está, en el ejemplo inicio a 1.)

El 1 es el step de incremento, podemos hacerlo de 2 en 2 o lo que queramos. "Campo" es el campo de la base de datos a incrementar. Este código puede ponerse en una Stored Procedure o bien en un Trigger. (Desde Delphi, ojo con los refrescos, sino el campo parece que no se insertó).

Importante: Los generadores son atransaccionales, eso significa que si usamos un generador para generar números correlativos desde una transacción pueden no ser consecutivos, dependiendo de si acabamos bien o no, ya que el rollback no recupera el valor del generador. (Se pueden usar técnicas de doble generador para este menester).

Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar

RE:Como creo un campo autonumerico en interbase

Publicado por Pablo (2 intervenciones) el 13/03/2003 08:44:17
Vale, crearlo es facil, e inicializarlo tambien. Luego se pueden insertar los nuevos valores con la funcion gen_id. Pero ¿Cómo se puede saber el último valor insertado? He colocado esta pregunta en la raiz del tema, a ver si alguien me la puede resolver.
Gracias
Valora esta respuesta
Me gusta: Está respuesta es útil y esta claraNo me gusta: Está respuesta no esta clara o no es útil
0
Comentar