使用SqlKata执行多个查询

时间:2018-05-01 15:18:29

标签: c# sqlkata

是否可以同时使用SqlKata执行多个查询。

目前我有以下代码:

var latestUsersQuery = db.Query("tbl_users").Where("created_at", ">", from);
var activitiesQuery = db.Query("tbl_activities").WhereIn("user_id", latestUsersQuery.Clone());

我单独询问每个人。

var latestUsers = latestUsersQuery.Get();
var activities = activitiesQuery().Get();

我想知道是否有办法同时执行两个查询。

// for example something like this
var results = db.GetAll(latestUsersQuery, activitiesQuery);

感谢。

1 个答案:

答案 0 :(得分:2)

在这方面,我们可以扩展SqlKata的QueryFactory类,类似于他们编写其他方法的方式。使用扩展方法。

using SqlKata;
using SqlKata.Execution;
using System.Collections.Generic;
using System.Linq;
// ...

public static class QueryFactoryExtensions
{
    public static IEnumerable<IEnumerable<T>> GetAll<T>(this QueryFactory db, params Query[] queries)
    {
        return queries.Select(q =>
        {
            return SqlKata.Execution.QueryFactoryExtensions.Get<T>(db, q);
        });
    }
    public static IEnumerable<IEnumerable<dynamic>> GetAll(this QueryFactory db, params Query[] queries)
    {
        return GetAll<dynamic>(db, queries);
    }
}

用法如下:

var query1 = new Query();
var query2 = new Query();

var results = db.GetAll(query1, query2)

您可以在此处进行枚举,将其转换为数组并按索引进行访问等。

请记住,这里并没有像OP注释中提到的那样向数据库发送一个查询。如果 performance 确实是您想要的,那么您可能会使用Dapper扩展方法 QueryMultiple 而不是 查询 (这是SqlKata在Get()方法上调用的内容)。我不太熟悉Dapper所做的基本魔术,以便能够自信地为您指明方向。您的另一种可能是添加 GetAsync 的扩展名,而不是 Get 。该 可能更适合您的需求。

所有这些都说明了,至少我希望这为您提供决策或潜在基准性能的指导。