我有一个checkboxlist。所选(选中)的项目存储在中List<string> selected。
checkboxlist
List<string> selected
例如,选择的值monday,tuesday,thursday超过7天
monday,tuesday,thursday
我正在转换List<>为以逗号分隔的string,即
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)