使用官方c#驱动程序在mongodb中保存具有双向关系的对象

我有两个这样的课:
public Class Company
{
    public IList<Employee> Employees;
}

public Class Employee
{
    public Company WorkPlace;
}

当我想保存类公司的对象时:

MongoDatabase Database = MongoServer.GetDatabase("db");

var workPlace = new Company();

var employee = new Employee { WorkPalce = workPlace}    
workPlace.Employees = new List<Employee>{ employee };

Database.GetCollection<Company>("company").Save(workPlace);

将抛出StackOverFlow异常.

解决方法

这是因为你有一个由相互引用的类形成的循环,显然驱动程序没有能力处理这个问题,我不相信它应该.

您需要决定如何在数据库中建模此数据.
如果您有两个集合,一个是公司,另一个是员工,那么在数据级别,您应该只包括引用的ID.

如果您只是拥有一个公司集合,那么您只需要更改员工类以引用带有id而不是对象引用的公司.

这只需要在数据库中进行,你可以在c#代码中扩展你的模型以自动添加对象引用或延迟加载它等(避免选择N 1问题),具体取决于适合的情况.

相关文章

在要实现单例模式的类当中添加如下代码:实例化的时候:frmC...
1、如果制作圆角窗体,窗体先继承DOTNETBAR的:public parti...
根据网上资料,自己很粗略的实现了一个winform搜索提示,但是...
近期在做DSOFramer这个控件,打算自己弄一个自定义控件来封装...
今天玩了一把WMI,查询了一下电脑的硬件信息,感觉很多代码都...
最近在研究WinWordControl这个控件,因为上级要求在系统里,...