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