LiteDB集合已返回,但查询返回null

时间:2018-06-25 18:00:08

标签: c# uwp nosql litedb

我已经做了相当多的研究,但是找不到(与我一样)同样问题的人。我正在使用LiteDB创建NoSQL数据库。

当程序首次运行并创建数据库时,以下示例中的查询工作正常。当我重新启动该程序时,它不能说它为null。奇怪的是,如果我进行计数,它将返回8条记录。所以某物存在-为什么我不能将其拔出?

这是我的代码:

public class ExternalTools
{
    public int Id { get; set; }
    public string Name { get; set; }
    public string[] Types { get; set; }
}

public void GetAll()
{
     var localFolder = Windows.Storage.ApplicationData.Current.LocalFolder;
     var folderPath = localFolder.Path;
     var filePath = Path.Combine(folderPath, @"MyData4.db");

     using (var db = new LiteDatabase(filePath))
     {
          Tools = db.GetCollection<ExternalTools>("externalTools");

          if (Tools.Count() == 0)
          {
              CreateToolList();

              // Index document using document Name property
              Tools.EnsureIndex(x => x.Name);
            }
      }

      Debug.WriteLine(Tools.Count());
      var temp = Tools.FindAll(); // null error
      var test = Tools.FindById(1); // another null error
      Debug.WriteLine(test.Name); //

}

谢谢!

1 个答案:

答案 0 :(得分:0)

好吧,我弄清楚了(浪费了很多小时的调试!)我的代码在错误的位置,如果我将其移到using语句中,它就可以正常工作。我怀疑这与以下事实有关:第一次运行时,它会向集合中添加内容,因此具有适当的参考。无论如何,此代码都有效:

        using (var db = new LiteDatabase(filePath))
        {
            Tools = db.GetCollection<ExternalTools>("externalTools");

            if (Tools.Count() == 0)
            {
                CreateToolList();

                // Index document using document Name property
                Tools.EnsureIndex(x => x.Name);
            }

            Debug.WriteLine(Tools.Count());
            var temp = Tools.FindAll(); // null error
            var test = Tools.FindById(1); // another null error
            Debug.WriteLine(test.Name); //
        }