加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

asp.net – 如何在SQL Server存储过程中使用逗号分隔(拆分)字符

发布时间:2020-12-16 06:33:22 所属栏目:asp.Net 来源:网络整理
导读:我有一个复选框列表.所选(已检查)的项目存储在List string中.选择. 例如,选择的值是星期一,星期二,星期四,7天 我正在转换List以逗号分隔的字符串,即 string a= "monday,tuesday,thursday" 现在,我将此值作为字符串传递给存储过程.我想解雇像: Select * from
我有一个复选框列表.所选(已检查)的项目存储在List< string>中.选择.

例如,选择的值是星期一,星期二,星期四,7天

我正在转换List<>以逗号分隔的字符串,即

string a= "monday,tuesday,thursday"

现在,我将此值作为字符串传递给存储过程.我想解雇像:

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

我的问题是:如何在存储过程中分离字符串?

解决方法

如果您将逗号分隔(任何分隔符)字符串传递给存储过程并在查询中使用,那么必须吐出该字符串然后您将使用它.

下面有例子:

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读