12

I have this table structure. YearPart, MonthPart and DatePart contain what they describe... EX: 2011, 1, 19 (respectively)

DECLARE @agenda AS TABLE    (
  PID INT IDENTITY(1,1) PRIMARY KEY,
  YearPart int,
  MonthPart int,
  DayPart int,
  lib_title nvarchar(200),
  [filename] nvarchar(255),
  meta_value nvarchar(2000)
)

Using this sample data:

INSERT INTO @agenda VALUES (2010, 12, 4, 'Test Record', '', '')
INSERT INTO @agenda VALUES (2011, 1, 3, 'Another Record', '', '')
INSERT INTO @agenda VALUES (2011, 1, 3, 'Fred Birthday', '', '')
INSERT INTO @agenda VALUES (2011, 1, 4, 'Work Day', '', '')
INSERT INTO @agenda VALUES (2011, 12, 6, '2nd Test Record', '', '')

What I want, is an XML output like this:

<root>
  <Year Year="2010">
    <Month Month="12">
      <Day Day="4">
        <Item RecordName="Test Record" RecordID="1" />
      </Day>
    </Month>
  </Year>
  <Year Year="2011">
    <Month Month="1">
      <Day Day="3">
        <Item RecordName="Another Record" RecordID="2" />
        <Item RecordName="Geoffrey Birthday" RecordID="3" />
      </Day> 
      <Day Day="4">
        <Item RecordName="Work Day" RecordID="4" />
      </Day>
    </Month>
    <Month Month="12">
      <Day Day="6">
        <Item RecordName="2nd Test Record" RecordID="5" />
      </Day>
    </Month>
  </Year>
</root>

So far, I haven't been able to get the nesting to work right. I usually end up with the grouping off (for example, I get multiple Year=2011 elements, when there should only be one).

If this can't be done, I can always create the XML on the .NET site...

1 Answer 1

17

It can be done.

select 
  a1.YearPart as '@Year',
  ( select MonthPart as '@Month',
      (select DayPart as '@Day',
         (select
            lib_title as '@RecordName', 
            PID as '@RecordID'
          from @agenda as a4
          where a4.DayPart = a3.DayPart and
                a4.MonthPart = a2.MonthPart and
                a4.YearPart = a1.YearPart
          for xml path('Item'), type         
         )
       from @agenda as a3
       where a3.YearPart = a1.YearPart and
             a3.MonthPart = a2.MonthPart
       group by a3.DayPart
       for xml path('Day'), type      
      )
    from @agenda as a2
    where a1.YearPart = a2.YearPart
    group by a2.MonthPart
    for xml path('Month'), type
  )  
from @agenda as a1
group by YearPart
for xml path('Year'), root
Sign up to request clarification or add additional context in comments.

1 Comment

Excellent! I knew I was close... I had my groups wrong... thanks Mikael... does exactly what I needed.

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.