PDA

Ver la Versión Completa : Pasar parametro DateTime nulo


YaninaGenia
19-07-2006, 16:00:47
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:

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.


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


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
Hector tenias razon, lo que hice para arreglar mi aplicacion fue modificar el Query del stored procedure:

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