我的行业就像'2,4,5'......并希望显示与行业ID相关的结果。 SQL SERVER

时间:2011-12-01 12:49:23

标签: sql

我有IndustryID喜欢'2,4,5'...并希望显示与IndustryID相关联的结果。但事情是在详细信息表中它将值存储为逗号分隔的2,4,5。因此,使用IN运算符只会使IndustryID等于2或4或5。

这是我的查询

Declare @IndustryID varchar(50)
set @IndustryID='2,4,5'

select IndustryID,Industry from DetailsMaster 
where (Industry IN (SELECT * from fnList2Table (@IndustryID))))
这里有

fnList2Table这个函数:

ALTER  FUNCTION [dbo].[fnList2Table]
(
    @List varchar(MAX)
)
RETURNS 
@ParsedList table
(
    item varchar(MAX)
)
AS
BEGIN
    DECLARE @item varchar(800), @Pos int

    SET @List = LTRIM(RTRIM(@List))+ ','
    SET @Pos = CHARINDEX(',', @List, 1)

    WHILE @Pos > 0
    BEGIN
        SET @item = LTRIM(RTRIM(LEFT(@List, @Pos - 1)))
        IF @item <> ''
        BEGIN
            INSERT INTO @ParsedList (item) 
            VALUES (CAST(@item AS int))
        END
        SET @List = RIGHT(@List, LEN(@List) - @Pos)
        SET @Pos = CHARINDEX(',', @List, 1)
    END

    RETURN
END

请提供答案。

1 个答案:

答案 0 :(得分:0)

使用此UDF将逗号分隔的字符串转换为行值,并在查询中使用它,如--- IN(选择dbo.udf_splitStringToRows(@IndustryID))

CREATE FUNCTION dbo.udf_List2Table
(
  @List VARCHAR(MAX),
  @Delim CHAR
)
RETURNS @ParsedList TABLE
(
  item VARCHAR(MAX)
)
AS
BEGIN
  DECLARE @item VARCHAR(MAX), @Pos INT
  SET @List = LTRIM(RTRIM(@List))+ @Delim
  SET @Pos = CHARINDEX(@Delim, @List, 1)
  WHILE @Pos > 0 BEGIN
    SET @item = LTRIM(RTRIM(LEFT(@List, @Pos - 1)))
    IF @item <> '' BEGIN
      INSERT INTO @ParsedList (item)
        VALUES (CAST(@item AS VARCHAR(MAX)))
    END
    SET @List = RIGHT(@List, LEN(@List) - @Pos)
    SET @Pos = CHARINDEX(@Delim, @List, 1)
  END
  RETURN
END
GO