1
试图从集合中获取文档,并且文档包含嵌套文档。试图获取包含嵌套文档的文档
获得一个错误信息“预期表示Project.Models.MapTags值的序列化形式的嵌套文件,但发现字符串的值而不是”
这里是代码
这是获取集合并执行查询的方法。
public List<Maps> GetAllMapsByUserId(ObjectId userId)
{
using (_server.RequestStart(_db))
{
var query = Query.EQ("UserId", userId);
MongoCursor<Maps> maps = _db.GetCollection<Maps>"Maps").FindAs<Maps>(query);
var list = maps.ToList();
return list;
}
}
这是一个包含对象
namespace Project.Models
{
public class Maps {
[BsonId]
public ObjectId Id { get; set; }
public ObjectId UserId { get; set; }
public string MapName { get; set; }
public string Description { get; set; }
public BsonBoolean PublicMap { get; set; }
public DateTime Created { get; set; }
[BsonIgnoreIfNull]
public List<MapTags> Tags { get; set; }
[BsonIgnoreIfNull]
public List<MapVotes> Votes { get; set; }
}
public class MapVotes
{
public ObjectId VoterId { get; set; }
public int VoteValue { get; set; }
}
public class MapTags
{
public string Tag { get; set; }
}
}
希望有人有很长一段时间的想法/提示或类似的,一直在寻找和测试,并没有发现一个解决方案的类。
更新:
下面是数据在数据库
{
"_id" : ObjectId("4eda2415851e702684bf6392"),
"MapName" : "Test",
"Description" : "Test",
"Created" : ISODate("2011-12-03T13:28:53.698Z"),
"PublicMap" : false,
"UserId" : ObjectId("4e8033a0851e701c7c1e12e1"),
"Tags" : [ "Test", "Kalle", "Jonas", "Fredrik" ]
}
新增了数据在数据库中的外观示例,删除了所有旧数据并重新创建了新数据。 – Forser
证实了这一假设。相应地更新答案 – mnemosyn