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
  #2  
Antiguo 19-08-2014
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.806
Poder: 22
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
Las reglas no cambiaron, siempre fue así (por lo menos desde que era Interbase/Firebird 1.0.
Si algo no cambia, el new.value y el old.value serán iguales.

De todos modos no entiendo como haces la asociación. Supongo que has omitido el hecho de que la tabla lotes tiene también el cliente...
En ese caso, deberías verificar si esta disponible o no, solamente en el momento de asociar a un cliente. Quedaría algo así:
Código SQL [-]
CREATE trigger asociar_lote_cliente for lotes
active before update position 0
AS
begin
  /* Solamente si estoy modificando el cliente */
  if (new.cliente <> old.cliente) then
  begin
    /* Solamente podemos asociar un cliente con un lote que esté DISPONIBLE */
    if (new.estado_lote = 'OCUPADO' and old.estado_lote = 'OCUPADO') then
    begin
      exception lote_no_disponible;
    end
  end
end
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
Trigger josi SQL 2 26-03-2008 03:27:57
Un trigger que dispara un procedimiento que dispara un trigger... sitrico Firebird e Interbase 5 04-06-2007 22:05:13
Duda Sobre trigger DANIELMW Firebird e Interbase 3 29-01-2004 23:31:48
trigger acertij022 Firebird e Interbase 6 20-10-2003 19:20:31


La franja horaria es GMT +2. Ahora son las 01:06:45.


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