Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/csharp/329.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
C# XmlSerializer-linq to sql-序列化类型的对象时检测到循环引用_C#_Linq To Sql - Fatal编程技术网

C# XmlSerializer-linq to sql-序列化类型的对象时检测到循环引用

C# XmlSerializer-linq to sql-序列化类型的对象时检测到循环引用,c#,linq-to-sql,C#,Linq To Sql,我试图在我的linq to sql MVC2 webapp中使用XmlSerializer在数据库中存储复杂对象。在过去的3天里,我一直在谷歌上搜索和实验,无法通过这个循环引用错误。我读过很多关于如何解决这个问题的文章,但没有一篇对我有用。我一直在尝试这个策略,因为很多相关文章都链接到了这个。因此,本文似乎正在成为一种流行的方法: 我曾尝试在LINQtoSQL中为循环引用问题实现这个建议的修复,但它根本不起作用。我进行了三重/四重检查,确认我正在将所有子属性访问修饰符更改为内部,但没有效果。无

我试图在我的linq to sql MVC2 webapp中使用XmlSerializer在数据库中存储复杂对象。在过去的3天里,我一直在谷歌上搜索和实验,无法通过这个循环引用错误。我读过很多关于如何解决这个问题的文章,但没有一篇对我有用。我一直在尝试这个策略,因为很多相关文章都链接到了这个。因此,本文似乎正在成为一种流行的方法:

我曾尝试在LINQtoSQL中为循环引用问题实现这个建议的修复,但它根本不起作用。我进行了三重/四重检查,确认我正在将所有子属性访问修饰符更改为内部,但没有效果。无论我做什么,我总是得到循环参考误差。当然,每次更改课程后,我都会重新编译。我确保将父属性访问修饰符保留为public

根据我读到的另一篇文章,我还尝试将以下内容归因于所有EntitySet: [System.Xml.Serialization.XmlIgnore]

这对我也不起作用——同样的错误

我没有使用WCF,只是在一个带有MVC2的webapp中使用linq到sql。我可以将非linq对象序列化为sql对象,而无需考虑复杂性

以下是我的序列化程序函数:

private static string SerializeToString(object obj)
    {
        XmlSerializerNamespaces ns = new XmlSerializerNamespaces();
        ns.Add("", ""); 

        XmlSerializer serializer = new XmlSerializer(obj.GetType(), "");
        using (StringWriter writer = new StringWriter())
        {
            serializer.Serialize(writer, obj, ns);
            return writer.ToString();
        }
    }

如果有人对此有想法的话,我很想听听。

循环引用发生在你必须对相互引用的对象进行引用时。序列化程序不支持此类引用

例如:

public class Object1
{
    public Object2 SecondObject { get; set; } 
}


public class Object2
{
    public Object1 FirstObject { get; set; } 
}

埃斯彭·布罗德是对的。不要直接序列化实体。相反,创建一个数据传输模型并序列化该模型。您可以使用AutoMapper在两者之间进行映射。

您能给出一些关于模型的指示吗?特别是关联属性?正是linq to sql自动在所有位置放置循环引用。正如我在帖子中提到的,设置内部参数应该可以防止这种情况发生,但显然不能。我不是手动创建相互引用的类。所以这并没有真正的帮助。我们最终对应用程序进行了大规模重构,不再存储对象。那很有趣。谢谢大家。:-)