2

有人可以帮我解决以下问题吗?

楷模

public class Integer
{
    public int IntegerID { get; set; }

    [Required(ErrorMessage = "Enter an integer")]
    [Integer(ErrorMessage = "Enter an integer")]
    public int IntegerValue { get; set; }
    public int IntegerListID { get; set; }

    public virtual IntegerList IntegerList { get; set; }
}

public class IntegerList
{ 
    public int IntegerListID { get; set; }
    public string Direction { get; set; }
    public long Performance { get; set; }
    public virtual ICollection<Integer> Integers { get; set; }

    public IntegerList()
    {
        Integers = new List<Integer>();
    }
}

控制器动作

    public ActionResult XMLexport () {
        Object obj = db.IntegerLists.Include("Integers");
        Serialize(obj);
        return View();
    }
    public static string Serialize(Object obj)
    {
        DataContractSerializer serializer = new DataContractSerializer(obj.GetType());
        MemoryStream memoryStream = new MemoryStream();
        serializer.WriteObject(memoryStream, obj);
        return Encoding.UTF8.GetString(memoryStream.GetBuffer());
    }

在线上

serializer.WriteObject(memoryStream, obj);

我收到错误:

Type 'System.Data.Entity.Infrastructure.DbQuery`1[[IntegerSorter.Models.IntegerList,     IntegerSorter, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null]]' is an invalid collection type since it does not have a valid Add method with parameter of type 'IntegerSorter.Models.IntegerList'.

有人可以告诉我在哪里以及如何实现 Add 方法吗?

更新:

改变:

Object obj = db.IntegerLists.Include("Integers");

Object obj = db.IntegerLists.Include("Integers").ToList();

结果是:

Type 'System.Data.Entity.DynamicProxies.IntegerList_62F0932A6DFC38A25629DF18911498D42B3785A93BCE8B8D2F77C3363B3F4200' with data contract name 'IntegerList_62F0932A6DFC38A25629DF18911498D42B3785A93BCE8B8D2F77C3363B3F4200:http://schemas.datacontract.org/2004/07/System.Data.Entity.DynamicProxies' is not expected. Consider using a DataContractResolver or add any types not known statically to the list of known types - for example, by using the KnownTypeAttribute attribute or by adding them to the list of known types passed to DataContractSerializer.
4

2 回答 2

2

Try changing this line:

Object obj = db.IntegerLists.Include("Integers");

To this:

Object obj = db.IntegerLists.Include("Integers").ToList();

This will cause the database query to run and give you a List<IntegerList> instead of a DbQuery<IntegerList>. This should then provide what the serializer wants (because it has a Add(IntegerList) method available as requested by the error).

于 2013-10-14T16:11:44.100 回答
0

我已经接受了 Greg 的回答,但我觉得我应该详细说明我必须解决的后续问题:

Type 'System.Data.Entity.DynamicProxies.IntegerList_62F0932A6DFC38A25629DF18911498D42B3785A93BCE8B8D2F77C3363B3F4200' with data contract name 'IntegerList_62F0932A6DFC38A25629DF18911498D42B3785A93BCE8B8D2F77C3363B3F4200:http://schemas.datacontract.org/2004/07/System.Data.Entity.DynamicProxies' is not expected. Consider using a DataContractResolver or add any types not known statically to the list of known types - for example, by using the KnownTypeAttribute attribute or by adding them to the list of known types passed to DataContractSerializer.

解决了:

Context.Configuration.ProxyCreationEnabled = false;

接着:

Object graph for type 'System.Collections.Generic.List`1[[IntegerSorter.Models.Integer, IntegerSorter, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null]]' contains cycles and cannot be serialized if reference tracking is disabled.

通过装饰 Integer 类的导航属性解决了如下问题:

[IgnoreDataMember]
public virtual IntegerList IntegerList { get; set; }
于 2013-10-15T11:44:24.487 回答