我有一个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)
关于asp.net - 如何在 SQL Server 存储过程中用逗号分隔(分割)字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23089579/