Sqlserver
 sql >> база данни >  >> RDS >> Sqlserver

Как да разделя (разделя) низ със запетая в съхранена процедура на SQL Server

Ако предадете низа, разделен със запетая (всякакъв разделител), към процедурата за съхраняване и използване в заявката, трябва да трябва да изплюете този низ и след това ще го използвате.

По-долу има пример:

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. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Компресиране на специфичен дял в таблица в SQL Server (T-SQL)

  2. SQl сървър Трябва да коригирам грешката за изтичане на времето за изчакване. Периодът на изчакване изтече

  3. Как да изчислим възрастта (в години) въз основа на датата на раждане и getDate()

  4. scope_identity срещу ident_current

  5. Ще върне ли TSQL по-бързи резултати от съхранената процедура в SQL Server