Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Firebird e Interbase (https://www.clubdelphi.com/foros/forumdisplay.php?f=19)
-   -   Limpiar fecha (https://www.clubdelphi.com/foros/showthread.php?t=75996)

lledesma 03-10-2011 03:44:00

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

RONPABLO 03-10-2011 07:00:08

Si el parámetro va desde delphi yo haría algo así:

Código Delphi [-]
...
Egreso.ParamByName('INGRESO').clear;
Egreso.ParamByName('EGRESO').clear;
...

duilioisola 03-10-2011 11:22:40

¿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.

guillotmarc 03-10-2011 12:50:09

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.

lledesma 03-10-2011 16:42:29

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.

guillotmarc 03-10-2011 17:56:21

Cita:

Empezado por lledesma (Mensaje 414370)
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 ?.

lledesma 04-10-2011 15:47:25

Lo encontré:

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

Muchas gracias por interesarse.


La franja horaria es GMT +2. Ahora son las 05:22:44.

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