SQL - using a variable for an IN clause

后端 未结 7 1391
醉话见心
醉话见心 2021-01-21 09:50

I wish to do something like the following:

declare @FrameNumber nvarchar(20)
set @FrameNumber = \'(p1, p2)\'

select from myTable where c1 in @FrameNumber


        
相关标签:
7条回答
  • 2021-01-21 09:53
    DECLARE @FrameNumbers TABLE (code NVARCHAR(20) PRIMARY KEY)
    
    INSERT
    INTO   @framenumbers
    VALUES ('p1')
    
    INSERT
    INTO   @framenumbers
    VALUES ('p2')
    
    SELECT  *
    FROM    mytable
    WHERE   c1 IN
            (
            SELECT  code
            FROM    @framenumbers
            )
    
    0 讨论(0)
  • 2021-01-21 09:59

    If you are using Sql Server 2005+ have a look at this

    --Split
    DECLARE @textXML XML
    DECLARE @data NVARCHAR(MAX), 
            @delimiter NVARCHAR(5)
    
    SELECT  @data = 'A,B,C',
            @delimiter = ','
    
    SELECT    @textXML = CAST('<d>' + REPLACE(@data, @delimiter, '</d><d>') + '</d>' AS XML)
    SELECT  T.split.value('.', 'nvarchar(max)') AS data
    FROM    @textXML.nodes('/d') T(split)
    

    You can you that as your in table to select from.

    Have a look at XML Support in Microsoft SQL Server 2005

    0 讨论(0)
  • 2021-01-21 10:04

    You could put load those values into a table variable, or you could use dynamic sql. Here are examples of each:

    TABLE VARIABLE

    DECLARE @FrameNumbers TABLE (
        Frame NVARCHAR(20)
    )
    
    INSERT INTO @FrameNumbers (
        Frame
    )
    SELECT 'p1'
    UNION ALL SELECT 'p2'
    

    option 1:

    SELECT * FROM myTable WHERE c1 in (
        SELECT Frame
        FROM @FrameNumbers
    )
    

    option 2:

    SELECT
        m.*
    FROM myTable m
    INNER JOIN @FrameNumbers f ON f.Frame = m.c1
    

    All that is fine, but this is my favorite:

    DYNAMIC SQL

    DECLARE 
    @FrameNumber nvarchar(20),
    @sql nvarchar(max),
    @ParamDef nvarchar(1000)
    
    SET @FrameNumber = '(p1, p2)'
    
    SET @sql = N'SELECT FROM myTable WHERE c1 IN ' + @FrameNumber
    
    EXECUTE dbo.sp_ExecuteSQL @sql
    
    0 讨论(0)
  • 2021-01-21 10:09

    I have another solution to do with split function,

    DECLARE @FrameNumber NVARCHAR(20)
    SET @FrameNumber = 'p1,p2'
    
    SELECT * FROM MyTable WHERE ProductCode IN 
    (SELECT Value FROM fn_Split(@FrameNumber, ','))
    

    OutPut:

    Split Functions:

    CREATE FUNCTION fn_Split (
        @String VARCHAR(8000)
        ,@Delimiter CHAR(1)
        )
    RETURNS @temptable TABLE (Value VARCHAR(8000))
    AS
    BEGIN
        DECLARE @idx INT
        DECLARE @slice VARCHAR(8000)
    
        SELECT @idx = 1
    
        IF len(@String) < 1
            OR @String IS NULL
            RETURN
    
        WHILE @idx != 0
        BEGIN
            SET @idx = charindex(@Delimiter, @String)
    
            IF @idx != 0
                SET @slice = left(@String, @idx - 1)
            ELSE
                SET @slice = @String
    
            IF (len(@slice) > 0)
                INSERT INTO @temptable (Value)
                VALUES (@slice)
    
            SET @String = right(@String, len(@String) - @idx)
    
            IF len(@String) = 0
                BREAK
        END
    
        RETURN
    END
    
    0 讨论(0)
  • 2021-01-21 10:09

    what version of SQL Server ?

    If you are in 2008 you might be able to use table datatypes. Simplifies these things a lot.

    0 讨论(0)
  • 2021-01-21 10:12
    CREATE FUNCTION [dbo].[func_ParseStringToTable] (@stringIN varchar(2000)) 
    RETURNS @tOUT TABLE(RoomID int) AS
    BEGIN
    DECLARE @pos int
    SET @pos=CHARINDEX(',',@StringIN)
    WHILE @pos>0
         BEGIN
         INSERT @tOUT(RoomID) SELECT LEFT(@StringIN,CHARINDEX(',',@StringIN)-1)
         SET @stringIN = SUBSTRING(@StringIN,CHARINDEX(',',@StringIN)+1,LEN(@StringIN))
         SET @pos=CHARINDEX(',',@StringIN)
         END
    IF LEN(@StringIN)>0
         BEGIN
         INSERT @tOUT(RoomID) SELECT @StringIN
         END
    RETURN 
    END
    

    usage...

    SELECT * FROM table WHERE id IN (func_ParseStringToTable(@ids))
    
    0 讨论(0)
提交回复
热议问题