Here is an example of a left join:
var joinXml = from m in result.Descendants("Report")
join o in ordered.Descendants("Report")
on (string)m.Attribute("name").Value.ToLower()
equals (string)o.Attribute("name").Value.ToLower()
into mainGroup
let orderedMatch = (
from x in mainGroup.DefaultIfEmpty()
where x != null
select new XElement("Report",
new XAttribute("name", m.Attribute("name").Value),
new XAttribute("trend", "true"))
)
let orderedNoMatch = (
from y in mainGroup.DefaultIfEmpty()
where y == null
select new XElement("Report",
new XAttribute("name", m.Attribute("name").Value),
new XAttribute("trend", "false"))
)
let total = orderedMatch.Concat(orderedNoMatch)
select total;