MongoDB.Bson.Serialization 的文档似乎很薄。我不知道如何正确地将我的自定义集合放入 MongoDB 文档中。我正在使用他们的默认 c# Driver。
这是我要序列化的类,但是当我在序列化然后反序列化之后查看结果时,集合是空的。更具体地说,它创建了该类的一个新实例,但“_items”集合为空。鉴于它是私人室内收藏品,我发现这很不寻常。该集合是一个更大类的属性,其他类属性正在正确序列化。我一直在使用内置的序列化程序将其序列化为 XML,并且效果很好。我认为这可能很简单,但是没有创建自定义序列化实现,我不知道它是什么。我必须做些什么来告诉序列化程序将其视为一个集合吗?
由于我是 MongoDB 的新手,我还没有弄清楚如何转储大型原始文档来检查 MongoDB 文档本身的样子。这就是我现在正在做的事情。
[XmlRootAttribute(ElementName = "Children", IsNullable = true)]
public class ChildList : IList<SurveyItem>, ICollection<SurveyItem>
{
private SurveyItem _parent = null;
public ChildList(SurveyItem iParent)
{
_parent = iParent;
}
private List<SurveyItem> items = new List<SurveyItem>();
#region ICollection<SurveyItem> Members
public void Add(SurveyItem item)
{
//wire up the child.
item.Parent = _parent;
items.Add(item);
}
public void Clear()
{
items.Clear();
}
public bool Contains(SurveyItem item)
{
return items.Contains(item);
}
public void CopyTo(SurveyItem[] array, int arrayIndex)
{
items.CopyTo(array, arrayIndex);
}
public int Count
{
get { return items.Count; }
}
public bool IsReadOnly
{
get { return false; }
}
public bool Remove(SurveyItem item)
{
item.Parent = null;
return items.Remove(item);
}
#endregion
#region IEnumerable<SurveyItem> Members
public IEnumerator<SurveyItem> GetEnumerator()
{
return items.GetEnumerator();
}
#endregion
#region IEnumerable Members
IEnumerator IEnumerable.GetEnumerator()
{
return (items as IEnumerable).GetEnumerator();
}
#endregion
#region IList<SurveyItem> Members
public int IndexOf(SurveyItem item)
{
return items.IndexOf(item);
}
public void Insert(int index, SurveyItem item)
{
item.Parent = _parent;
items.Insert(index, item);
}
public void RemoveAt(int index)
{
items[index].Parent = null;
items.RemoveAt(index);
}
public SurveyItem this[int index]
{
get
{
return items[index];
}
set
{
value.Parent = _parent;
items[index] = value;
}
}
#endregion
public SurveyItem[] ToArray()
{
SurveyItem[] output = new SurveyItem[items.Count];
for (int i = 0; i < items.Count; i++)
{
output[i] = items[i];
}
return output;
}
}