Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   .NET (https://www.clubdelphi.com/foros/forumdisplay.php?f=17)
-   -   Pasar parametro DateTime nulo (https://www.clubdelphi.com/foros/showthread.php?t=33869)

YaninaGenia 19-07-2006 16:00:47

Pasar parametro DateTime nulo
 
Holaaaa
Estoy trabajando con un stored procedure que recibe tres fechas que podrian ser ingresadas por el usuario o no. Si el usuario no ingresa una de ellas, y hago
parSendDate.Value =
null;
el stored procedure se rompe, y tiene razon porque no recibe ningun parametro. Hay alguna forma de mandarle la fecha vacia y que el stored procedure lo reconozca? Por las dudas, el query que contiene es este:
Código:

ALTER PROCEDURE dbo.FiltersResultOrden
(@client
int, @createdDate datetime, @deliverDate datetime, @sendDate datetime)
AS
SELECT *
FROM Orden
WHERE ((cliente = @client)or(@client = 0))
AND ((fechaCreada = @createdDate)or(@createdDate is null))
AND ((fechaEnviada = @deliverDate)or(@deliverDate is null))
AND ((fechaEntregada = @sendDate)or(@sendDate is null))



edgusano 19-07-2006 19:02:12

Podrias asignarle una fecha antigua con lo cual indicarias que no se ingreso nada en ese parametro, asi no llegarian valores nulos y simplemente en el stored procedure validarias si viene el valor por default, con lo cual sabrias que no se ingreso esa fecha.

YaninaGenia 19-07-2006 19:30:20

...
 
Pero dejaria de funcionarme el Stored Procedure, ya que esta hecho para recibir o no tal parametro.

Yanina Genia

edgusano 20-07-2006 00:18:31

Umm tienes razon en eso.

Si es en sql Server puedes en la creacion del stored procedure decirle a el parametro que si no viene ningun valor tome uno por defecto.

Create procedure dbo.FiltersResultOrden (@client int,
@createdDate
datetime = '20000101', @deliverDate datetime = '20000101', @sendDate datetime = '20000101')
AS
SELECT * FROM Orden WHERE ((cliente = @client)or(@client = 0))
AND ((fechaCreada = @createdDate)or(@createdDate is null))
AND ((fechaEnviada = @deliverDate)or(@deliverDate is null))
AND ((fechaEntregada = @sendDate)or(@sendDate is null))

Pregunta, en esos campos se pueden almacenar valores nulos.?

__hector 20-07-2006 21:30:25

tambien puedes igualar el valor del parametro a null.

Código SQL [-]
ALTER PROCEDURE dbo.FiltersResultOrden
(@client int, 
@createdDate datetime = null, 
@deliverDate datetime = null, 
@sendDate datetime = null)
AS
SELECT *
FROM Orden
WHERE (cliente = @client or @client = 0)
AND (fechaCreada = @createdDate or @createdDate is null)
AND (fechaEnviada = @deliverDate or @deliverDate is null)
AND (fechaEntregada = @sendDate or @sendDate is null)

YaninaGenia 21-07-2006 14:51:51

....
 
No puedo preguntarle por null ya que no se pueden enviar parametros nulos al stored procedure, si le envio ese valor me da un cartel de error diciendo que faltaron esos parametros.

Yanina Genia

YaninaGenia 21-07-2006 14:57:32

Cita:

Empezado por edgusano
Umm tienes razon en eso.

Si es en sql Server puedes en la creacion del stored procedure decirle a el parametro que si no viene ningun valor tome uno por defecto.

Create procedure dbo.FiltersResultOrden (@client int,
@createdDate
datetime = '20000101', @deliverDate datetime = '20000101', @sendDate datetime = '20000101')
AS
SELECT * FROM Orden WHERE ((cliente = @client)or(@client = 0))
AND ((fechaCreada = @createdDate)or(@createdDate is null))
AND ((fechaEnviada = @deliverDate)or(@deliverDate is null))
AND ((fechaEntregada = @sendDate)or(@sendDate is null))


No me va a servir porque el SP va a buscar las fechas con esos valores que yo le asigne en lugar de NO buscar.

Cita:

Empezado por edgusano
Pregunta, en esos campos se pueden almacenar valores nulos.?

No, pero si el usuario ingresa una sola fecha en lugar de todas, tengo que traer todos los resultados que coincidan, no es que voy a preguntar por los campos que esten nulos si el usuario no ingreso nada para ellos.

Yanina Genia

__hector 21-07-2006 19:10:09

Yanina:

Cuando asignas un valor a un parametro al momento de declararlo, automaticamente el parametro es considerado opcional, por lo que no es necesario pasarle valores al parametro (o pasarle un valor nulo), y el procedimiento se ejecutara sin problemas.

En el ejemplo que plantee, puedes verificar que tiene justamente ese comportamiento. Si quieres prueba desde el query analyzer con:

EXEC FiltersResultOrden idcliente, null, fecha

EXEC FiltersResultOrden idcliente, fecha

EXEC FiltersResultOrden idcliente, null, null, fecha

Todos deben ejecutarse correctamente. Lo mismo sucederia en el desarrollo, cuando no le especifiques un valor al parametro, simplemente el valor para el procedimiento sera null, por lo que las condiciones especificadas en el WHERE se ejecutaran de la forma deseada.

YaninaGenia 25-07-2006 22:49:59

Si
 
Hector tenias razon, lo que hice para arreglar mi aplicacion fue modificar el Query del stored procedure:
Código:


ALTER PROCEDURE
dbo.FiltersResultOrden
(@client
int, @createdDate varchar(10) = null, @deliverDate varchar(10) = null, @sendDate varchar(10) = null)
AS
SELECT *
FROM Orden
WHERE ((cliente = @client)or(@client = 0))
AND ((fechaCreada = @createdDate)or(@createdDate is null))
AND ((fechaEnviada = @deliverDate)or(@deliverDate is null))
AND ((fechaEntregada = @sendDate)or(@sendDate is null))

De esta manera si no le paso parametros toma null por default, antes no me dejaba si no le enviaba todos los parametros a traves del codigo.

Yanina Genia


La franja horaria es GMT +2. Ahora son las 12:46:34.

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