![]() |
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 |
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.
|
...
Pero dejaria de funcionarme el Stored Procedure, ya que esta hecho para recibir o no tal parametro.
Yanina Genia |
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.? |
tambien puedes igualar el valor del parametro a null.
|
....
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 |
Cita:
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:
Yanina Genia |
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. |
Si
Hector tenias razon, lo que hice para arreglar mi aplicacion fue modificar el Query del stored procedure:
Código:
Yanina Genia |
La franja horaria es GMT +2. Ahora son las 03:21:19. |
Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi