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)
这是我现在唯一的选择,还是有另一种更清晰的方式在代码中表达这一点?
进行投影时,请使用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)
| 归档时间: |
|
| 查看次数: |
1869 次 |
| 最近记录: |