Ver Mensaje Individual
  #2  
Antiguo 09-06-2008
Avatar de Delphius
[Delphius] Delphius is offline
Miembro Premium
 
Registrado: jul 2004
Ubicación: Salta, Argentina
Posts: 5.582
Reputación: 25
Delphius Va camino a la fama
Lo que tu estás buscando se consigue con un generador y un trigger:

Un ejemplo de un generador:
Código SQL [-]
CREATE GENERATOR EMP_NO_GEN;

Un generador pemite llevar ese incremento. Y puede, si se desea, indicarle un valor inicial:
Código SQL [-]
SET GENERATOR EMP_NO_GEN TO 145;

En el ejemplo vale 145.

Y un ejemplo de un trigger:

Código SQL [-]
CREATE TRIGGER SET_EMP_NO FOR EMPLOYEE
ACTIVE BEFORE INSERT POSITION 0
AS
BEGIN
    /* FIXED by helebor 19.01.2004 */
    if (new.emp_no is null) then
    new.emp_no = gen_id(emp_no_gen, 1);
END
La función gen_id() recibe como parámetro un generador y un valor de incremento. En este caso de 1.

El disparador (Trigger) se dispara antes de insertar (en este ejemplo). En tu caso debe ser AFTER INSERT.

Entonces, antes de insertar en la tabla, se dispara el trigger, llama a la función gen_id() con el generador en cuestión. Al final del proceso, el valor obtenido es 146.

Los ejemplos que te pasee fueron extraídos de la DB de ejemplo EMPLOYEE que acompaña a la instalación de Firebird.

Sería bueno ahora darte una pequeña advertencia: el uso de los generadores violan el concepto de transaccionalidad. Es decir que si en una transacción se ejecutan dichos procesos, un rollback no volverá el valor hacia atrás.

Deberás analizar efectivamente si el uso de los generadores es que estás buscando. Puesto que también hay otras maneras de conseguir este efecto.

Saludos,
__________________
Delphius
[Guia de estilo][Buscar]
Responder Con Cita