如果传递逗号分隔(任何分隔符)的字符串来存储过程并在查询中使用,那么必须吐出该字符串,然后才能使用它。
下面有例子:
DECLARE @str VARCHAr(500) = 'monday,tuesday,thursday'CREATE TABLE #Temp (tDay VARCHAr(100))WHILE LEN(@str) > 0BEGIN DECLARE @TDay VARCHAr(100) IF CHARINDEX(',',@str) > 0 SET @TDay = SUBSTRINg(@str,0,CHARINDEX(',',@str)) ELSE BEGIN SET @TDay = @str SET @str = '' END INSERT INTO #Temp VALUES (@TDay) SET @str = REPLACe(@str,@TDay + ',' , '') END SELECT * FROM tblx WHERe days IN (SELECt tDay FROM #Temp)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)