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 03-10-2011
lledesma lledesma is offline
Miembro
 
Registrado: abr 2004
Posts: 43
Poder: 0
lledesma Va por buen camino
Limpiar fecha

Hola comunidad:
Como hacer para limpiar un campo fecha en un procedure firebird?. Da un error tipo : invalid data convertions.
quiero que el campo fecha de una tabla quede en blanco como cuando se crea por primera vez.. Se puede?. EL procedure lo indico abajo, cuando paso como parametro null en ingreso o egreso me da el error.

Código SQL [-]
SET TERM ^ ;

CREATE PROCEDURE VINASIS (
    DOC CHAR(11),
    ANO INTEGER,
    INGRESO DATE,
    EGRESO DATE)
RETURNS (
    IDALUMNO INTEGER)
AS
begin
  SELECT idalumno FROM alumnos WHERE DOC=:doc INTO :IDALUMNO;
  if (idalumno IS NOT NULL) then
  begin
    UPDATE alumnos set EGRESO=:egreso,INGRESO=:ingreso WHERE IDALUMNO=:IDALUMNO;
    if ((:ANO<>0) and (:ano>=extract(year from current_date))) then
    BEGIN
        update asigcursos set INGRESO=:INGRESO,EGRESO=:EGRESO where ano=:ano and idalumno=:idalumno;
    END
  END
  suspend;
end
^

SET TERM ; ^

Que parametro deberia pasar para porder limpiar los campos ingreso o egreso?
Gracias por el tiempo
__________________
Atentamente
Luis

Última edición por lledesma fecha: 03-10-2011 a las 03:47:15.
Responder Con Cita
  #2  
Antiguo 03-10-2011
Avatar de RONPABLO
[RONPABLO] RONPABLO is offline
Miembro Premium
 
Registrado: oct 2004
Posts: 1.514
Poder: 21
RONPABLO Va por buen camino
Si el parámetro va desde delphi yo haría algo así:

Código Delphi [-]
...
Egreso.ParamByName('INGRESO').clear;
Egreso.ParamByName('EGRESO').clear;
...
__________________
"Como pasa el tiempo..... ayer se escribe sin H y hoy con H"
Responder Con Cita
  #3  
Antiguo 03-10-2011
Avatar de duilioisola
[duilioisola] duilioisola is offline
Miembro Premium
 
Registrado: ago 2007
Ubicación: Barcelona, España
Posts: 1.734
Poder: 20
duilioisola Es un diamante en brutoduilioisola Es un diamante en brutoduilioisola Es un diamante en bruto
¿Cómo llamas al procedimiento?
Código SQL [-]
EXECUTE PROCEDURE VINASIS ('DOC', 2011, null, null)
o 
SELECT * FROM VINASIS ('DOC', 2011, null, null)
Ten en cuenta que el parámetro null no va entre comillas.

Si el problema no es el de las comillas, puede que tengas un trigger sobre la tabla asigcursos que trate de hacer algo con la fecha y no acepte null como parámetro.
Responder Con Cita
  #4  
Antiguo 03-10-2011
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
En principio el procedimiento almacenado está bien, y como dices, el valor a pasar en los parámetros es NULL.

¿ Puedes enseñarnos el código Delphi con el que llamas al procedimiento almacenado ?, quizás no asignas bien el valor NULL a los parámetros.

También puedes tener un trigger (disparador) en la tabla, que opere con los campos INGRESO y EGRESO y que provoque el error al encontrarse con el valor NULL.

Saludos.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #5  
Antiguo 03-10-2011
lledesma lledesma is offline
Miembro
 
Registrado: abr 2004
Posts: 43
Poder: 0
lledesma Va por buen camino
Gracias por las respuestas.

En realidad el procedure es invocado desde un motor de datos mssql. Tenemos dos sistemas uno con firebird y otro con mssql. Si utilizo execute procedure desde firebird y paso los parametros null tambien me da el error. El procedure no se invoca desde delphi. No acepta el null si el formato del parametro es date.
__________________
Atentamente
Luis
Responder Con Cita
  #6  
Antiguo 03-10-2011
Avatar de guillotmarc
guillotmarc guillotmarc is offline
Miembro
 
Registrado: may 2003
Ubicación: Huelva
Posts: 2.638
Poder: 24
guillotmarc Va por buen camino
Cita:
Empezado por lledesma Ver Mensaje
Gracias por las respuestas.

En realidad el procedure es invocado desde un motor de datos mssql. Tenemos dos sistemas uno con firebird y otro con mssql. Si utilizo execute procedure desde firebird y paso los parametros null tambien me da el error. El procedure no se invoca desde delphi. No acepta el null si el formato del parametro es date.
¿ Has revisado los triggers de la tabla ?, ¿ y sus constraints ?.
__________________
Marc Guillot (Hi ha 10 tipus de persones, els que saben binari i els que no).
Responder Con Cita
  #7  
Antiguo 04-10-2011
lledesma lledesma is offline
Miembro
 
Registrado: abr 2004
Posts: 43
Poder: 0
lledesma Va por buen camino
Lo encontré:

Código SQL [-]
 execute procedure ('20202020',2011,cast(null as date),cast(null as date))

Muchas gracias por interesarse.
__________________
Atentamente
Luis
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
Limpiar un DBEdit loquillo3 Varios 3 08-04-2008 17:07:50
Limpiar un TreeView lucero_chivas C++ Builder 2 22-11-2006 06:12:39
Limpiar BD interbase jmlifi Firebird e Interbase 3 13-01-2006 13:18:19
limpiar un DBLookupComboBox lola OOP 4 07-10-2005 21:40:14
limpiar acentos User_baja1 Varios 5 07-09-2005 23:14:30


La franja horaria es GMT +2. Ahora son las 12:24:17.


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