sql >> Databasteknik >  >> RDS >> Sqlserver

Hur man separerar (split) sträng med kommatecken i SQL Server lagrad procedur

Om du skickar den kommaseparerade (valfri avgränsare) sträng för att lagra proceduren och använda i frågan så måste du behöva spotta den strängen och sedan kommer du att använda den.

Nedan finns exempel:

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)


  1. Syntax för for-loop i SQL Server

  2. Infoga XML med mer än 4000 tecken i en Oracle XMLTYPE-kolumn

  3. 12c Flytta datafiler online

  4. Anslutningssträngsparametrar för Schema.ini