2011-12-03 50 views
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" ] 
    } 

回答

1

它看起来像串行期望一个文件的例子,但发现一个字符串。

的问题是,你已经连载字符串数组:

{ 
    "MapName" : "SomeMapName" 
    "Tags" : ["tag1", "tag2"] // list of strings 
    // ... 
} 

但你应该有

{ 
    "MapName" : "SomeMapName" 
    "Tags" : [ { /* map tag document */ }, { /* map tag document */ }, ...] 
    // ... 
} 

解串器希望找到一个文档,但仅找到字符串。现在有可能MapTag类基本上可以使用字符串进行序列化,并且可以从字符串重建,但是您必须为provide a custom serializer。这非常简单。

+0

新增了数据在数据库中的外观示例,删除了所有旧数据并重新创建了新数据。 – Forser

+0

证实了这一假设。相应地更新答案 – mnemosyn