sql >> Database teknologi >  >> RDS >> Sqlserver

Sådan adskilles (opdeles) streng med komma i SQL Server-lagret procedure

Hvis du sender den kommaseparerede (en hvilken som helst separator) streng for at gemme procedure og bruge i forespørgslen, så skal du spytte den streng, og så vil du bruge den.

Nedenfor har du et eksempel:

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. Hvorfor indsætter denne lagrede procedure NULL-værdier i tabellen?

  2. Alvorlige problemer med MySQL-forespørgslens ydeevne efter tilføjelse af betingelse

  3. HikariCP pass Oracle brugerdefineret type

  4. FEJL:mere end én række returneret af en underforespørgsel, der bruges som et udtryk