Linq BLToolkit中的表值函数

Linq BLToolkit中的表值函数,linq,user-defined-functions,bltoolkit,Linq,User Defined Functions,Bltoolkit,是否可以通过使用BLToolkit库来使用SQL Server表值函数 我想在Linq查询中使用它,但在库中找不到与此相关的任何内容。在数据上下文类中定义函数,如下所示: [TableFunction(Name="GetParentByID")] public Table<Parent> GetParentByID(int? id) { return GetTable<Parent>(this, (MethodInfo)MethodBase.GetCurrentM

是否可以通过使用BLToolkit库来使用SQL Server表值函数


我想在Linq查询中使用它,但在库中找不到与此相关的任何内容。

在数据上下文类中定义函数,如下所示:

[TableFunction(Name="GetParentByID")]
public Table<Parent> GetParentByID(int? id)
{
    return GetTable<Parent>(this, (MethodInfo)MethodBase.GetCurrentMethod(), id);
}
SQL:

您还可以在数据上下文之外定义它:

public class Functions
{
    private readonly IDataContext _ctx;

    public Functions(IDataContext ctx)
    {
        _ctx = ctx;
    }

    [TableFunction]
    public Table<Parent> GetParentByID(int? id)
    {
        return _ctx.GetTable<Parent>(this, (MethodInfo)(MethodBase.GetCurrentMethod()), id);
    }

    [TableExpression("{0} {1} WITH (TABLOCK)")]
    public Table<T> WithTabLock<T>()
        where T : class 
    {
        return _ctx.GetTable<T>(this, ((MethodInfo)(MethodBase.GetCurrentMethod())).MakeGenericMethod(typeof(T)));
    }
}

[Test]
public void Func1()
{
    using (var db = new TestDbManager())
    {
        var q =
            from p in new Functions(db).GetParentByID(1)
            select p;

        q.ToList();
    }
}

[Test]
public void WithTabLock()
{
    using (var db = new TestDbManager())
    {
        var q =
            from p in new Functions(db).WithTabLock<Parent>()
            select p;

        q.ToList();
    }
}
SELECT
    [t2].[ParentID],
    [t2].[Value1]
FROM
    [Child] [t1], [GetParentByID](2) [t2]
public class Functions
{
    private readonly IDataContext _ctx;

    public Functions(IDataContext ctx)
    {
        _ctx = ctx;
    }

    [TableFunction]
    public Table<Parent> GetParentByID(int? id)
    {
        return _ctx.GetTable<Parent>(this, (MethodInfo)(MethodBase.GetCurrentMethod()), id);
    }

    [TableExpression("{0} {1} WITH (TABLOCK)")]
    public Table<T> WithTabLock<T>()
        where T : class 
    {
        return _ctx.GetTable<T>(this, ((MethodInfo)(MethodBase.GetCurrentMethod())).MakeGenericMethod(typeof(T)));
    }
}

[Test]
public void Func1()
{
    using (var db = new TestDbManager())
    {
        var q =
            from p in new Functions(db).GetParentByID(1)
            select p;

        q.ToList();
    }
}

[Test]
public void WithTabLock()
{
    using (var db = new TestDbManager())
    {
        var q =
            from p in new Functions(db).WithTabLock<Parent>()
            select p;

        q.ToList();
    }
}
SELECT
    [p].[ParentID],
    [p].[Value1]
FROM
    [GetParentByID](1) [p]

SELECT
    [p].[ParentID],
    [p].[Value1]
FROM
    [Parent] [p] WITH (TABLOCK)