sql >> Databasteknik >  >> RDS >> Sqlserver

Gör en separat rad om en kolumn innehåller kommaavgränsade värden

Du kan skriva en fråga som:

DECLARE @employee TABLE (FirstName  VARCHAR(100),
                         LastName   VARCHAR(100),
                         PayScale INT)

INSERT INTO @employee VALUES 
('Craig','L',150000) , 
('Alice,Lisa','simons',100000)



SELECT Split.a.value('.', 'VARCHAR(100)') AS FirstName  , LastName  ,PayScale
       FROM  (SELECT  CAST ('<M>' + REPLACE(FirstName, ',', '</M><M>') + '</M>' 
                             AS XML) AS FirstName ,  LastName    ,PayScale
               FROM  @employee) 
       AS A 
CROSS APPLY FirstName.nodes ('/M') AS Split(a)



  1. mysql INTE I QUERY optimera

  2. MySQL - INSERT INTO från en tillfällig tabell

  3. Hur man undviker fel aggregerade funktioner är inte tillåtna i WHERE

  4. Hur konverterar man villkorligt tum till cm i MySQL (eller liknande konverteringar under SELECT)?