Asp.net

如何在 SQL Server 儲存過程中用逗號分隔(拆分)字元串

  • November 2, 2018

我有一個checkboxlist. 選定(選中)的項目儲存在List<string> selected.

例如,選擇的值monday,tuesday,thursday超出 7 天

我正在轉換List<>為逗號分隔string,即

string a= "monday,tuesday,thursday"

現在,我將此值作為字元串傳遞給儲存過程。我想觸發如下查詢:

Select * 
from tblx 
where days = 'Monday' or days = 'Tuesday' or days = 'Thursday'`

我的問題是:如何在儲存過程中分隔字元串?

如果您將逗號分隔(任何分隔符)字元串傳遞給儲存過程並在查詢中使用,那麼必須需要吐出該字元串,然後您才能使用它。

下面有例子:

DECLARE @str VARCHAR(500) = 'monday,tuesday,thursday'
CREATE TABLE #Temp (tDay VARCHAR(100))
WHILE LEN(@str) > 0
BEGIN
   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)

引用自:https://stackoverflow.com/questions/23089579