Club Delphi  
    Paypal   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

 
 
Herramientas Buscar en Tema Desplegado
  #4  
Antiguo 15-10-2006
Avatar de Crandel
[Crandel] Crandel is offline
Miembro Premium
 
Registrado: may 2003
Ubicación: Parana, Argentina
Posts: 1.475
Poder: 25
Crandel Va por buen camino
El problema es que tu campo ID lo declaraste que no puede ser nulo, por lo que no puedes intentar ingresarlo sin que darle un valor al ID.

Hay varias posibles soluciones:
1. Darle un valor por defecto, por ejemplo cero. luego en el trigger lo reemplazas por el valor autoincremental.

Código SQL [-]
CREATE TRIGGER "SET_DETALLE" FOR "DETALLE" 
ACTIVE BEFORE INSERT POSITION 0
AS
BEGIN
  NEW.IDDETALLE = GEN_ID(GENIDDETALLE,1);
END ^

2. Ingresar el valor a traves de un procedimiento almacenado, le pasas tods los paramentros menos el ID, ahi adentro calculas el nuevo ID y se lo asignas.

Código SQL [-]
CREATE PROCEDURE ING_DETALLE
(
  IDPRODUCTO  INTEGER,
  CANTIDAD FLOAT
)
AS
  DECLARE VARIABLE ID INTEGER;
BEGIN
  ID = gen_id(INC_CONST, 1);

  INSERT INTO DETALLE(IDDETALLE, IDPRODUCTO, CANTIDAD)
    VALUES (:ID, :IDPRODUCTO, :CANTIDAD);
END^

y posiblemente otras soluciones.
__________________
[Crandel]
Responder Con Cita
 



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
Autoincrementar Campo tipo 00/000 Niko Conexión con bases de datos 1 24-09-2005 20:57:25


La franja horaria es GMT +2. Ahora son las 22:19:37.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi