Foros del Web » Programación para mayores de 30 ;) » Bases de Datos General » SQL Server »

Como pasar parametros al operador IN (SQL)

Estas en el tema de Como pasar parametros al operador IN (SQL) en el foro de SQL Server en Foros del Web. Hola Amigos soy nuevo aqui he buscado alguna idea de como solucionar esto el problema es que quiero mostrar los tipos de recordatorios y lo ...
  #1 (permalink)  
Antiguo 30/10/2012, 08:35
 
Fecha de Ingreso: octubre-2006
Mensajes: 48
Antigüedad: 18 años, 1 mes
Puntos: 0
Como pasar parametros al operador IN (SQL)

Hola

Amigos soy nuevo aqui he buscado alguna idea de como solucionar esto
el problema es que quiero mostrar los tipos de recordatorios y lo hago
de esta manera.

Código:
             SELECT  *
             FROM    tblrecordatorios AS a
             WHERE a.RecordatorioTipoID IN ('PC1','PC2')
El problema es que cuando esto lo pase a un reporte y quiero pasarle como parametros el tipo de recoradatorio no muestra resultados

miren :


Código:
            DECLARE @itipoRecordatorio VARCHAR(15)
             SET  @itipoRecordatorio='PC1,PC2'

             SELECT  *
             FROM    tblrecordatorios AS a
             WHERE a.RecordatorioTipoID IN (@itipoRecordatorio)
pero no muestra resultados a que se debe?

mil gracias por su atención.
  #2 (permalink)  
Antiguo 30/10/2012, 09:09
Avatar de Libras
Colaborador
 
Fecha de Ingreso: agosto-2006
Ubicación: En la hermosa perla de occidente
Mensajes: 7.412
Antigüedad: 18 años, 3 meses
Puntos: 774
Respuesta: Como pasar parametros al operador IN (SQL)

A que no puedes pasar parametros en el in de esa manera deberias de hacer una funcion algo como esto:

Código SQL:
Ver original
  1. /****** Object:  UserDefinedFunction [dbo].[SplitApplication]    Script Date: 10/19/2010 15:12:35 ******/
  2. SET ANSI_NULLS ON
  3. GO
  4.  
  5. SET QUOTED_IDENTIFIER ON
  6. GO
  7.  
  8. CREATE FUNCTION [dbo].[SplitApplication](@applicationid VARCHAR(2000))
  9.  
  10. RETURNS @RtnValue TABLE
  11. (
  12. Id INT IDENTITY(1,1),
  13. DATA nvarchar(100)
  14. )
  15. AS
  16. BEGIN
  17. DECLARE @Cnt INT, @SplitOn nvarchar(5)
  18. SET @SplitOn = ','
  19. SET @Cnt = 1
  20.  
  21. While (Charindex(@SplitOn,@applicationid)>0)
  22. BEGIN
  23. INSERT INTO @RtnValue (DATA)
  24. SELECT
  25. DATA = ltrim(rtrim(SUBSTRING(@applicationid,1,Charindex(@SplitOn,@applicationid)-1)))
  26.  
  27. SET @applicationid = SUBSTRING(@applicationid,Charindex(@SplitOn,@applicationid)+1,len(@applicationid))
  28. SET @Cnt = @Cnt + 1
  29. END
  30.  
  31. INSERT INTO @RtnValue (DATA)
  32. SELECT DATA = ltrim(rtrim(@applicationid))
  33.  
  34. RETURN
  35. END
  36.  
  37. GO
  38.  
  39.  
  40. how TO USE :
  41.  
  42. SELECT * FROM TABLE WHERE DATA IN (
  43.  
  44. SELECT * FROM SplitApplication('1,1,1,1')
  45. )


saludos!
__________________
What does an execution plan say to t-sql query? Go f**k yourself, if you are not happy with me
  #3 (permalink)  
Antiguo 30/10/2012, 09:24
 
Fecha de Ingreso: octubre-2006
Mensajes: 48
Antigüedad: 18 años, 1 mes
Puntos: 0
Respuesta: Como pasar parametros al operador IN (SQL)

Libras,

Gracias por tu Gran ayuda lo estoy poniendo en practica para luego llevarlo a mi reporte

Muchas Gracias!

Que tengas un buen Día.

Develo

Etiquetas: operador, parametros, select
Atención: Estás leyendo un tema que no tiene actividad desde hace más de 6 MESES, te recomendamos abrir un Nuevo tema en lugar de responder al actual.
Respuesta




La zona horaria es GMT -6. Ahora son las 11:45.