[英]C# XmlSerializer from Entity Framework
我有2节课:
[XmlInclude(typeof(Item))]
public class A
{
public int Id { get; set; }
[XmlArray("Items")]
[XmlArrayItem("Item")]
public virtual List<Item> Items { get; set; } = new List<Item>();
}
public class Item
{
public int Id { get; set; }
[XmlIgnore]
public virtual A a { get; set; }
}
我在我的DbContext
使用此方法:
public virtual DbSet<A> A { get; set; }
public IQueryable<A> GetA()
{
return A;
}
现在我想将数据导出到XML:
Type[] types = { typeof(Item) };
var aElements = GetA().ToList();
System.Xml.Serialization.XmlSerializer writer =
new System.Xml.Serialization.XmlSerializer(aElements.GetType(), types);
writer.Serialize(file, aElements);
它抛出一个错误:
InvalidOperationException:不应预期类型System.Data.Entity.DynamicProxies.A_08D7BCCB892E27DE8C32342A0E8F0F2B2D3B9E2DAC9F6A16。 使用XmlInclude或SoapInclude属性可以指定静态未知的类型。
怎么了? 我尝试搜索类似的主题,但是这些解决方案对我不起作用。
编辑:预期结果:
<A>
<Id>1</Id>
<Items>
<Item><Id>20</Id></Item>
</Items>
</A>
<A>
..
</A>
您可能会收到此错误,因为Entity Framework将具有Proxies的Items集合替换为Items以支持延迟加载。 XmlSerializer不希望动态生成代理类型,因此会出现错误。
您可能可以通过为“项目”集合属性打开“延迟加载”来解决此问题。 请记住,通过关闭延迟加载,将始终填充Items集合,因此在某些情况下,它可能会给您带来一些意想不到的性能影响。
也许应该是;
public virtual DbSet<A> A{ get; set; }
public IQueryable<A> GetA()
{
return A.AsNoTracking();
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.