sql >> Database >  >> RDS >> Sqlserver

De beste manier om gegevens uit xml te halen met xquery

Ik heb een beetje vuile oplossing gevonden:

select ISNULL(Age1, case when Num>= 1 then 18 else -1 end) Age1
    , ISNULL(Age2, case when Num>= 2 then 18 else -1 end) Age2
    , ISNULL(Age3, case when Num>= 3 then 18 else -1 end) Age3
    , ISNULL(Age4, case when Num>= 4 then 18 else -1 end) Age4
from (
    select Persons.Person.value('@num','smallint') as Num
          ,Persons.Person.value('xs:integer(fn:number(@num))+1','int') as Num1
          ,Persons.Person.value('Person[@age<18][xs:integer(fn:number(../@num))][1]/@age','smallint') as Age1
          ,Persons.Person.value('Person[@age<18][xs:integer(fn:number(../@num))-1][1]/@age','smallint') as Age2
          ,Persons.Person.value('Person[@age<18][xs:integer(fn:number(../@num))-2][1]/@age','smallint') as Age3
          ,Persons.Person.value('Person[@age<18][xs:integer(fn:number(../@num))-3][1]/@age','smallint') as Age4 
    from @XmlData.nodes('/Persons') Persons(Person)
 ) Persons

Het idee van een oplossing is om eerst die contacten te extraheren die>=18 zijn, dan die te extraheren die 0

UPD:ondanks het feit dat de oplossing correcte resultaten opleverde, zijn de kosten hoog:~1000 in geschat uitvoeringsplan



  1. Hoe kan ik een afgeleide tabelquery die beter presteert dan het JOINed-equivalent verder optimaliseren?

  2. Kolom wijzigen, standaardbeperking toevoegen

  3. Oracle SQL converteert de datumnotatie van DD-Mon-YY naar YYYYMM

  4. TOAD beschouwt &String als bindvariabele