C#中的LiteDB多个查询

时间:2017-10-26 16:18:52

标签: c# .net wpf nosql litedb

我是 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));
            }               
        }         
    }

2 个答案:

答案 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中出现“缺口”,这会破坏您的代码。