sql >> Database >  >> RDS >> Sqlserver

Hoe een tekenreeks te scheiden (splitsen) met een komma in de opgeslagen procedure van SQL Server

Als u de door komma's gescheiden (elk scheidingsteken) tekenreeks doorgeeft om de procedure op te slaan en te gebruiken in de query, moet u die tekenreeks spugen en dan zult u deze gebruiken.

Hieronder een voorbeeld:

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. Wat is de snelste manier om tijdstempels in Postgres in te korten tot 5 minuten?

  2. mysql_fetch_assoc() fout wanneer gegevens in mysql-veld worden gewijzigd

  3. Postgres-fout in batch-insert:relatie hibernate_sequence bestaat niet positie 17

  4. Kan variabele binnen functie niet declareren op PostgreSQL