从Linq-to-Entities中选择Linq-to-XML?

Oce*_*t20 3 .net c# linq entity-framework linq-to-xml

在混合使用Linq-to-SQL和Linq-to-XML时,我曾经能够做到这样的事情:

XElement xml = new XElement("People");

xml.Add(from p in Context.People
        select new XElement("Person",
            new XElement("Id", p.Id),
            new XElement("Name", p.Name)));
Run Code Online (Sandbox Code Playgroud)

在将一些东西转换为EF时,我现在得到了这个例外:"LINQ to Entities中只支持无参数构造函数和初始值设定项."

这让我相信我现在需要做这样的事情:

XElement xml = new XElement("People");

var peopleResults = Context.People.Select(p => { p.Id, p.Name }).ToList();

xml.Add(from p in peopleResults
        select new XElement("Person",
            new XElement("Id", p.Id),
            new XElement("Name", p.Name)));
Run Code Online (Sandbox Code Playgroud)

这是我现在唯一的选择,还是有另一种更清晰的方式在代码中表达这一点?

Jef*_*ado 6

进行投影时,请使用LINQ to Objects.要做到这一点,请AsEnumerable()事先打电话.

XElement xml = new XElement("People");

xml.Add(from p in peopleResults.AsEnumerable()
        select new XElement("Person",
            new XElement("Id", p.Id),
            new XElement("Name", p.Name)));
Run Code Online (Sandbox Code Playgroud)