我已经做了相当多的研究,但是找不到(与我一样)同样问题的人。我正在使用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); //
}
谢谢!
答案 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); //
}