24

这是问题:

我有 2 个要加入的数据上下文。现在我知道 LINQ 不允许从一个上下文连接到另一个上下文,并且我知道 2 种可能的解决方案是创建单个数据上下文或具有 2 个单独的查询(这是我现在正在做的)。但是我想做的是“模拟”一个连接。

这是我尝试过的。

using (var _baseDataContext = Instance)
{
    var query = from a in _baseDataContext.Account.ACCOUNTs
                where a.STR_ACCOUNT_NUMBER.ToString() == accountID
                join app in _baseDataContext.Account.APPLICATIONs on a.GUID_ACCOUNT_ID equals
                            app.GUID_ACCOUNT
                join l in GetLoans() on app.GUID_APPLICATION equals l.GUID_APPLICATION
                select l.GUID_LOAN;

    return query.Count() > 0 ? query.First() : Guid.Empty;
}

private static IQueryable<LOAN> GetLoans()
{
    using (var _baseDataContext = Instance)
    {
        return (from l in _baseDataContext.Loan.LOANs
                select l).AsQueryable();
    }
}

在运行时我得到的是

System.InvalidOperationException:查询包含对在不同数据上下文中定义的项目的引用

编辑:

工作解决方案:

using (var _baseDataContext = Instance)
{
    var query = from a in _baseDataContext.Account.ACCOUNTs
                where a.STR_ACCOUNT_NUMBER.ToString() == accountID
                join app in _baseDataContext.Account.APPLICATIONs on a.GUID_ACCOUNT_ID equals
                           app.GUID_ACCOUNT
                join l in GetLoans() on app.GUID_APPLICATION equals l.GUID_APPLICATION 
                select l.GUID_LOAN;

     return (query.Count() > 0) ? query.First() : Guid.Empty;
}

private static IEnumerable<LOAN> GetLoans()
{
    using (var _baseDataContext = Instance)
    {
        return (from l in _baseDataContext.Loan.LOANs
                select l).AsQueryable();
    }
}
4

3 回答 3

16

也许这样的事情可以让你朝着正确的方向开始。我根据您的列名制作了一个包含类似列的模拟数据库,并得到了一些结果。

    class Program
{
    static AccountContextDataContext aContext = new AccountContextDataContext(@"Data Source=;Initial Catalog=;Integrated Security=True");
    static LoanContextDataContext lContext = new LoanContextDataContext(@"Data Source=;Initial Catalog=;Integrated Security=True");

    static void Main()
    {

        var query = from a in aContext.ACCOUNTs
                    join app in aContext.APPLICATIONs on a.GUID_ACCOUNT_ID equals app.GUID_ACCOUNT
                    where app.GUID_APPLICATION.ToString() == "24551D72-D4C2-428B-84BA-5837A25D8CF6"
                    select GetLoans(app.GUID_APPLICATION);

        IEnumerable<LOAN> loan = query.First();
        foreach (LOAN enumerable in loan)
        {
            Console.WriteLine(enumerable.GUID_LOAN);
        }

        Console.ReadLine();
    }

    private static IEnumerable<LOAN> GetLoans(Guid applicationGuid)
    {
        return (from l in lContext.LOANs where l.GUID_APPLICATION == applicationGuid select l).AsQueryable();
    }
}

希望这可以帮助!

于 2009-05-22T15:40:05.703 回答
3

这是我们发现的“解决方法”......

我们从另一个数据库手动构建我们的表,如果它在同一台服务器上,那么我们在表名前加上:

<DatabaseName>.<SchemaName>.<YourTableName>

如果它们在链接服务器上,那么您还必须在其前面加上服务器名称:

<ServerName>.<DatabaseName>.<SchemaName>.<YourTableName>

这将允许您进行连接并仍然返回一个未执行的 IQueryable... 这是我们想要的。其他两种方式涉及加入内存中的 IEnumerables,这意味着您在进行联接(上图)之前为每个记录提取所有记录,并使用具有限制的 contains 方法进行 IQueryable 联接...

希望将来 DataContext 将构建得足够智能,以知道如果服务器已链接,那么您可以在两个不同的服务器之间进行连接。

于 2009-05-22T16:23:47.260 回答
0

我赞成创建一个单独的数据上下文,其中只包含您要连接的两个表。但我想你可以在第二个上下文中维护一个临时表(包含第一个上下文中的数据),然后加入临时表。

于 2009-05-22T15:27:24.267 回答