LiteDB在执行查询时不返回任何数据

时间:2016-10-27 18:38:09

标签: c# litedb nosql

我试过到处寻找答案,但我认为我做错了什么但是弄不清楚是什么。

我有一个名为Genre的结构。 Genre有一个id和一个name

public struct Genre
{
        public int Id { get; set; }
        public string Name { get; set; }
}

我正确填充了DB文件,我的.db文件如下所示(来自公共API):

> db.MoviesGenres.find
[1]: {"_id":12,"Name":"Adventure"}
[2]: {"_id":14,"Name":"Fantasy"}
[3]: {"_id":16,"Name":"Animation"}
[4]: {"_id":18,"Name":"Drama"}
[5]: {"_id":27,"Name":"Horror"}
[6]: {"_id":28,"Name":"Action"}
[7]: {"_id":35,"Name":"Comedy"}
[8]: {"_id":36,"Name":"History"}
[9]: {"_id":37,"Name":"Western"}
[10]: {"_id":53,"Name":"Thriller"}
[11]: {"_id":80,"Name":"Crime"}
[12]: {"_id":99,"Name":"Documentary"}
[13]: {"_id":878,"Name":"Science Fiction"}
[14]: {"_id":9648,"Name":"Mystery"}
[15]: {"_id":10402,"Name":"Music"}
[16]: {"_id":10749,"Name":"Romance"}
[17]: {"_id":10751,"Name":"Family"}
[18]: {"_id":10752,"Name":"War"}
[19]: {"_id":10770,"Name":"TV Movie"}

到目前为止这么好,对吗?现在问题是当我试图再次获取该数据以在其他地方使用时。我有一个应该返回名称的方法,但它没有。

public static string GetGenre(int Id)
        {
            LitePlatform.Initialize(new LitePlatformFullDotNet());

            using (var Db = new LiteDatabase(Database.DataFile))
            {
                var Collection = Db.GetCollection<Genre>("MoviesGenres");

                Genre genre = Collection.FindOne(x => x.Id == Id);

                return genre.Name;
            }
        }

当我设置断点时,genre的值为id = 0name = null。当我执行静态调用Collection.FindOne(x => x.Name == "Animation")

时也会发生同样的情况

我错过了什么?

1 个答案:

答案 0 :(得分:0)

尝试在[BsonId]之前添加public int Id { get; set; }。另外,我认为结构存在查询问题。您可能希望使用类。