首先,创建分割功能,将您的分隔字符串转换成表格:
CREATE FUNCTION [dbo].[Split]
(
@String varchar(max)
,@Delimiter char
)
RETURNS @Results table
(
Ordinal int
,StringValue varchar(max)
)
as
begin
set @String = isnull(@String,'')
set @Delimiter = isnull(@Delimiter,'')
declare
@TempString varchar(max) = @String
,@Ordinal int = 0
,@CharIndex int = 0
set @CharIndex = charindex(@Delimiter, @TempString)
while @CharIndex != 0 begin
set @Ordinal += 1
insert @Results values
(
@Ordinal
,substring(@TempString, 0, @CharIndex)
)
set @TempString = substring(@TempString, @CharIndex + 1, len(@TempString) - @CharIndex)
set @CharIndex = charindex(@Delimiter, @TempString)
end
if @TempString != '' begin
set @Ordinal += 1
insert @Results values
(
@Ordinal
,@TempString
)
end
return
end
然后改变你的where子句如下:
select
t.*
from [yourTable] t
where t.[ID] not in (select cast([StringValue] as int) from dbo.Split(@sRemovePreviouslySelectedWhereClause,','))
没有被我所知道的任何供应商支持的SQL它支持使用变量为IN/NOT IN子句提供逗号分隔列表。使用动态SQL,或将值列表转换为表值函数/等进行比较。 – 2011-03-01 06:07:15
[SQL Server SP - 传递参数为“IN”数组列表?]的可能的重复(http://stackoverflow.com/questions/537087/sql-server-sp-pass-parameter-for-in-array-list) – onedaywhen 2011-03-01 08:16:35
这是最常见的问题之一。你会发现许多重复(或非常接近的问题)。 – onedaywhen 2011-03-01 08:17:31