我是 LiteDB 的新手,并希望一次执行两个或多个查询。
我希望能够在我的DataBase中搜索某个客户,并且因为会有多个具有相似名称的客户,我希望将其全部归还并按降序(Id或日期)订单进行排序。我有两种功能即兴但分开,所以我正在寻找一种方法将搜索和排序组合成一个查询。
这是主要的搜索功能:
private void search_btn_Click(object sender, RoutedEventArgs e)
{
using (var dataBase = new LiteDatabase(dbConnectionString))
{
// Stranka = Customer
var collection = dataBase.GetCollection<Stranka>("stranka");
// Search for a customer name whom I enter in the searchName_tb
var query = collection.Find(Query.Where("Ime_Priimek",
x => x.AsString.Contains(searchName_tb.Text)));
// Currently I'm doing everything with ListView, so I clear it
// to make room for resulting data to be shown
lvStranke.Items.Clear();
foreach (var customer in query)
{
lvStranke.Items.Add(customer);
}
}
}
这是我的加载/刷新时按降序排序的版本:
public void LiteDB_ShowAll()
{
using (var dataBase = new LiteDatabase(dbConnectionString))
{
var collection = dataBase.GetCollection<Stranka>("stranka");
lvStranke.Items.Clear();
var count = collection.Count(Query.All());
// From last ID to first (Descending)
for (int i = count; i >= 1; i--)
{
lvStranke.Items.Add(collection.FindById(i));
}
}
}
答案 0 :(得分:2)
搜索的最佳方法是在查询字段中使用索引并对结果进行排序,如下所示:
public void LiteDB_ShowAll()
{
using (var dataBase = new LiteDatabase(dbConnectionString))
{
var collection = dataBase.GetCollection<Stranka>("stranka");
collection.EnsureIndex("Ime_Priimek");
lvStranke.Items.Clear();
var result = collection
.Find(Query.StartsWith("Ime_Priimek", searchName_tb.Text))
.OrderBy(x => x["_id"].AsInt32);
foreach (var item in result)
{
lvStranke.Items.Add(item);
}
}
}
在这种情况下,您只需订购已过滤的文档。
答案 1 :(得分:0)
你看过Queries wiki page的例子了吗?看起来您可以使用LINQ对Find
所获得的对象进行排序,尽管这可以在客户端而不是引擎本身完成。
public void LiteDB_ShowAll()
{
using (var dataBase = new LiteDatabase(dbConnectionString))
{
var collection = dataBase.GetCollection<Stranka>("stranka");
lvStranke.Items.Clear();
foreach(var cust in collection.FindAll().OrderByDescending(x => x.Date)) // or by x.Id
{
lvStranke.Items.Add(cust);
}
}
}
LiteDB_ShowAll
实施的重要缺点并非效率低下。事实上,它期望永远不能从数据库中删除Customer
个对象,而这通常是不正确的。因此,您最终会在ID中出现“缺口”,这会破坏您的代码。